精华内容
下载资源
问答
  • div标签与其内的内容组成块元素、表示一块内容,没有具体的语义,唯一的格式就是换行,常结合CSS用于页面布局,span标签与其内的内容形成行内元素,没有具体的语义,常用于修改段落中的局部样式;表格标签分为table...

    今日头条文章新零售电商运营调研与架构设计报告2.1:新零售电商总体愿景
    ,欢迎浏览指正。

    一、HTML高级标签

    1.div与span标签

    div标签语法为:

    <div>内容</div>
    

    与其内的内容组成块元素、表示一块内容,没有具体的语义,唯一的格式就是换行,常结合CSS用于页面布局

    如下:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    <body>
        <div>你好</div>
        <div>你好</div>
    </body>
    </html>
    

    显示:
    html div

    可以看到,每一个div元素都占满一行

    与p标签对比如下:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    <body>
        <div>金樽清酒斗十千,玉盘珍羞直万钱。停杯投箸不能食,拔剑四顾心茫然。欲渡黄河冰塞川,将登太行雪满山。闲来垂钓碧溪上,忽复乘舟梦日边。行路难,行路难,多歧路,今安在?长风破浪会有时,直挂云帆济沧海。</div>
        <div>金樽清酒斗十千,玉盘珍羞直万钱。停杯投箸不能食,拔剑四顾心茫然。欲渡黄河冰塞川,将登太行雪满山。闲来垂钓碧溪上,忽复乘舟梦日边。行路难,行路难,多歧路,今安在?长风破浪会有时,直挂云帆济沧海。</div>
        <div>金樽清酒斗十千,玉盘珍羞直万钱。停杯投箸不能食,拔剑四顾心茫然。欲渡黄河冰塞川,将登太行雪满山。闲来垂钓碧溪上,忽复乘舟梦日边。行路难,行路难,多歧路,今安在?长风破浪会有时,直挂云帆济沧海。</div>
        <p>金樽清酒斗十千,玉盘珍羞直万钱。停杯投箸不能食,拔剑四顾心茫然。欲渡黄河冰塞川,将登太行雪满山。闲来垂钓碧溪上,忽复乘舟梦日边。行路难,行路难,多歧路,今安在?长风破浪会有时,直挂云帆济沧海。</p>
        <p>金樽清酒斗十千,玉盘珍羞直万钱。停杯投箸不能食,拔剑四顾心茫然。欲渡黄河冰塞川,将登太行雪满山。闲来垂钓碧溪上,忽复乘舟梦日边。行路难,行路难,多歧路,今安在?长风破浪会有时,直挂云帆济沧海。</p>
        <p>金樽清酒斗十千,玉盘珍羞直万钱。停杯投箸不能食,拔剑四顾心茫然。欲渡黄河冰塞川,将登太行雪满山。闲来垂钓碧溪上,忽复乘舟梦日边。行路难,行路难,多歧路,今安在?长风破浪会有时,直挂云帆济沧海。</p>
    </body>
    </html>
    

    显示:
    html div p

    显然,因为div元素除了占行没有任何格式,而p标签有段落的格式,因此在页面中表现出来的也不一样,p标签形成的段落之间有空格。

    span标签语法为:

    <span>内容</span>
    

    与其内的内容形成行内元素、内容有多宽就占用多宽的空间距离,没有具体的语义,常用于修改段落中的局部样式

    测试如下:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    <body>
        <div>金樽清酒斗十千,玉盘珍羞直万钱。停杯投箸不能食,拔剑四顾心茫然。欲渡黄河冰塞川,将登太行雪满山。闲来垂钓碧溪上,忽复乘舟梦日边。行路难,行路难,多歧路,今安在?长风破浪会有时,直挂云帆济沧海。</div>
        <div>金樽清酒斗十千,玉盘珍羞直万钱。停杯投箸不能食,拔剑四顾心茫然。欲渡黄河冰塞川,将登太行雪满山。闲来垂钓碧溪上,忽复乘舟梦日边。行路难,行路难,多歧路,今安在?长风破浪会有时,直挂云帆济沧海。</div>
        <div>
            <h1>span标签</h1>
            <p>金樽清酒斗十千,<span style="color: tomato;">玉盘珍羞直万钱</span>。停杯投箸不能食,拔剑四顾心茫然。欲渡黄河冰塞川,将登太行雪满山。闲来垂钓碧溪上,忽复乘舟梦日边。行路难,行路难,多歧路,今安在?长风破浪会有时,直挂云帆济沧海。</p>
        </div>
        
    </body>
    </html>
    

    显示:
    html span

    可以看到,sapn标签可以定义局部样式。

    2.表格标签

    语法为:

    <table>
        <tr>
            <td>第一行第一列</td>
            <td>第一行第二列</td>
        </tr>
        <tr>
            <td>第二行第一列</td>
            <td>第二行第二列</td>
        </tr>
    </table>
    

    其中的标签和意义如下:

    标签 意义
    table 表格
    tr 一行
    td(th) 一列(表头)

    测试如下:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    <body>
        <table>
            <tr>
                <td>第一行第一列</td>
                <td>第一行</td>
            </tr>
            <tr>
                <td>第一列</td>
                <td>第二行第二列</td>
            </tr>
        </table>
        
    </body>
    </html>
    

    显示:
    html table

    此时是没有表格边框的,要想显示边框,需要定义border属性

    table标签的常用属性及意义如下:

    table属性 意义
    border 表格边框(像素)
    width 表格宽度(像素)
    height 表格高度(像素)
    align 表格相对于父元素的对齐方式,取值分别为left(默认)、right、center

    测试如下:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    <body>
        <table border="1" width='200' height='80' align="center">
            <tr>
                <td>第一行第一列</td>
                <td>第一行</td>
            </tr>
            <tr>
                <td>第一列</td>
                <td>第二行第二列</td>
            </tr>
        </table>
        <table border="1" width='200' height='80'>
            <tr>
                <th>姓名</th>
                <th>性别</th>
            </tr>
            <tr>
                <td>张三</td>
                <td></td>
            </tr>
            <tr>
                <td>李四</td>
                <td></td>
            </tr>
        </table>
        
    </body>
    </html>
    

    显示:
    html table border

    显然,此时有更多的格式,包括边框、表格宽度、表格高度、表头格式、对齐方式等。

    同时,单元格即td(th)也有一些属性:

    td(th)属性 意义
    align 水平对齐,取值为left、right和center
    valign 垂直对齐,取值为top、bottom和middle
    colspan 水平合并
    rowspan 垂直合并

    水平和垂直对齐测试如下:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    <body>
        <table border="1" width='500' height='200' align="center">
            <tr>
                <td>第一行第一列</td>
                <td>第一行</td>
            </tr>
            <tr>
                <td>第一列</td>
                <td>第二行第二列</td>
            </tr>
        </table>
        <table border="1" width='500' height='200'>
            <tr>
                <th align="center">姓名</th>
                <th  align="center" valign='top'>性别</th>
            </tr>
            <tr>
                <td align="center" valign='bottom'>张三</td>
                <td align="center"></td>
            </tr>
            <tr>
                <td>李四</td>
                <td></td>
            </tr>
        </table>
        
    </body>
    </html>
    

    显示:
    html table border td

    表格还可以跨行和跨列合并单元格,这是需要用到td(th)的colspan和rowspan属性,测试如下:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    <body>
        <table border="1">
            <tr>
                <td rowspan="2" width='300' height='50'>姓名</td>
                <td colspan="2" width='300' height='50'>性别</td>
                <!-- <td></td> -->
            </tr>
            <tr>
                <!-- <td></td> -->
                <td align='center'></td>
                <td align='center'></td>
            </tr>
            <tr>
                <td align='center'>Corley</td>
                <td align='center'></td>
                <td align='center'></td>
            </tr>
            <tr>
                <td align='center'>Jack</td>
                <td align='center'></td>
                <td align='center'></td>
            </tr>
        </table>
        
    </body>
    </html>
    

    显示:
    html table span

    显然,已经实现了表格的横向和纵向跨行。

    3.表单标签

    表单标签form标签一般用来与用户交互并提交数据,语法如下:

    <form>
        <label>用户名: </label>
        <input type="text">
        ...
    </form>
    

    form标签有两个属性:
    action属性定义表单数据提交地址(空的默认为提交到当前页);
    method属性定义表单提交方式(get/post)。

    form标签可以定义许多子标签,包括label标签、input标签、textarea标签和select标签等。

    label标签为表单定义文字注释,便于用户直观了解标签的作用;
    for属性与label标签内部的表单标签的id名绑定,点击label区域激活该id标签。

    input标签包含很多属性,type属性定义了input标签的类型,如下:

    input标签type属性 意义
    text 文本(明文)输入框
    password 密文输入框
    radio 单选框,一般需要通过name属性来将指定的单选框捆绑到一组,如果要提交需要指定value属性
    checkbox 多选框,一般需要通过name属性来将指定的多选框捆绑到一组,如果要提交需要指定value属性
    submit 表单提交,可以通过value属性指定按钮显示值
    reset 重置,可以通过value属性指定按钮显示值
    file 文件上传

    textarea标签为多行文本输入框,语法如下:

    <textarea name="" id="" cols="30" rows="10"></textarea>
    

    通常需要设置cols和rows属性,当不设置cols属性与rows属性时,文本框可以自动收缩,会影响布局;
    提交时要设置name属性。

    select标签为下拉框,语法为:

    <select name="site">
        <option value="0">1</option>
        <option value="1">2</option>
        <option value="2">3</option>
        <option value="3">4</option>
    </select> 
    

    如果要提交数据,需要给select指定name属性、option指定value属性。

    测试如下:

    <!DOCTYPE html>
    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    
    <body>
        <form action="" method="GET">
            <div>
                <label for="">用户名:</label>
                <input type="text" name="username">
            </div>
            <div>
                <label for="">&nbsp;&nbsp;&nbsp;&nbsp;码:</label>
                <input type="password" name="password">
            </div>
            <div>
                <label for="">&nbsp;&nbsp;&nbsp;&nbsp;别:</label>
                <input type="radio" name="gender"><input type="radio" name="gender"></div>
            <div>
                <label for="">&nbsp;&nbsp;&nbsp;&nbsp;族:</label>
                <label for="major"><input type="radio" name="major" id="major">汉族</label>
                <label for="minor"><input type="radio" name="minor" id="minor">少数民族</label>
            </div>
            <div>
                <label for="">&nbsp;&nbsp;&nbsp;&nbsp;好:</label>
                <input type="checkbox" name="hobby">音乐
                <input type="checkbox" name="hobby">舞蹈
                <input type="checkbox" name="hobby">游戏
                <input type="checkbox" name="hobby">读书
                <input type="checkbox" name="hobby">爬山
            </div>
            <div>
                <input type="submit" value="点我一下">
            </div>
        </form>
        
    </body>
    
    </html>
    

    演示如下:
    html form get

    显然,在输入用户名和密码后,点击提交时,输入的值都作为参数传递到url中,但是密码等敏感信息也传递到url中显示出来会显得很不安全,所以可以使用POST方法。

    再次测试如下:

    <!DOCTYPE html>
    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    
    <body>
        <form action="" method="POST">
            <div>
                <label for="">用户名:</label>
                <input type="text" name="username">
            </div>
            <div>
                <label for="">&nbsp;&nbsp;&nbsp;&nbsp;码:</label>
                <input type="password" name="password">
            </div>
            <div>
                <label for="">&nbsp;&nbsp;&nbsp;&nbsp;别:</label>
                <input type="radio" name="gender" value="0"><input type="radio" name="gender" value="1"></div>
            <div>
                <label for="">&nbsp;&nbsp;&nbsp;&nbsp;族:</label>
                <label for="major"><input type="radio" name="major" id="major" value="0">汉族</label>
                <label for="minor"><input type="radio" name="minor" id="minor" value="1">少数民族</label>
            </div>
            <div>
                <label for="">&nbsp;&nbsp;&nbsp;&nbsp;好:</label>
                <input type="checkbox" name="hobby" value="0">音乐
                <input type="checkbox" name="hobby" value="1">舞蹈
                <input type="checkbox" name="hobby" value="2">游戏
                <input type="checkbox" name="hobby" value="3">读书
                <input type="checkbox" name="hobby" value="4">爬山
            </div>
            <div>
                <label for="">&nbsp;&nbsp;&nbsp;&nbsp;介:</label>
                <textarea name="" id="" cols="30" rows="10"></textarea>
            </div>
            <div>
                <label for="">&nbsp;&nbsp;&nbsp;&nbsp;市:</label>
                <select name="site">
                    <option value="0">北京</option>
                    <option value="1">上海</option>
                    <option value="2">广州</option>
                    <option value="3">成都</option>
                </select>                
            </div>
            <div>
                <input type="submit" value="点我一下">
                <input type="reset" value="重置">
            </div>
            
        </form>
        
    </body>
    
    </html>
    

    演示如下:
    html form post

    显然,此时不再将数据显示到url中。

    二、CSS基础

    1.CSS介绍

    CSS全称Cascading Style Sheets,即层叠样式表,样式定义了HTML元素如何显示,样式通常又会存在于样式表中。
    通常把HTML元素的样式都统一收集起来写在一个地方或一个CSS文件里。

    CSS的作用如下:

    • 美化网页
    • 将HTML页面的内容与样式分离
    • 提高Web开发的工作效率

    2.引入样式方式

    行内样式

    给body中需要添加样式的标签添加style属性。

    测试如下:

    <!DOCTYPE html>
    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>css引入</title>
        <!-- <link rel="stylesheet" href="css/main.css"> -->
        <style>
            h1 {
                color: tomato;
            }
        </style>
    </head>
    
    <body>
        <h1>CSS测试</h1>
        <div>
            <body>
                <a href="http://www.baidu.com" style="font-size:20px;color:chartreuse;">百度一下</a>
            </body>
        </div>
    </body>
    
    </html>
    

    显示:
    html css link

    嵌入式

    方式为在标签中添加style标签:

    <head>
        <meta charset="UTF-8">
        <title>html之css</title>
        <style>
            h1{
                color: tomato;
            }
        </style>
    </head>
    

    测试如下:

    <!DOCTYPE html>
    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>css引入</title>
        <!-- <link rel="stylesheet" href="css/main.css"> -->
        <style>
            h1{
                color: tomato;
            }
        </style>
    </head>
    
    <body>
        <h1>CSS测试</h1>
        <div>哪有什么岁月静好,不过是有人替你负重前行</div>
    </body>
    
    </html>
    

    显示:
    html css insert

    外联式

    步骤为:
    新建css为后缀的文件,并在文件中写css样式;
    在标签中导入css文件如下:

    <head>
        <meta charset="UTF-8">
        <link rel="stylesheet" href="css文件相对路径">
        <title>css引入</title>
    </head>
    

    测试如下:

    <!DOCTYPE html>
    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>css引入</title>
        <link rel="stylesheet" href="css/main.css">
    </head>
    
    <body>
        <h1>CSS测试</h1>
        <div>哪有什么岁月静好,不过是有人替你负重前行</div>
    </body>
    
    </html>
    

    在同级目录下创建css目录,下创建main.css如下:

    div{
        color: blueviolet;
    }
    

    此时显示:
    html css inline

    显然,已经显示出样式。

    在实际开发中,外联式最常使用,其次是嵌入式,最不建议使用的是行内样式。

    展开全文
  • 经常会有同学私信我说,应该怎么样系统的学习python和web呢,这几天老师也总结了不少的经验和列子,今天就告诉大家怎么样才是最系统的路线,让大家学习起来更有目标更高效。 相信小伙伴们都知道,目前Python主打的两...

    经常会有同学私信我说,应该怎么样系统的学习python和web呢,这几天老师也总结了不少的经验和列子,今天就告诉大家怎么样才是最系统的路线,让大家学习起来更有目标更高效。
    相信小伙伴们都知道,目前Python主打的两个方向:其一是网络爬虫,其二是web开发。如果将这两者完美的结合起来,可以说是天作之合。如果你前端和后端都搞得定,那么恭喜你,全栈工程师的这份殊荣是你的了。

    那么为什么要学习Python呢?Python是一种面向对象的计算机程序设计语言,也是一种功能强大,而且完善的通用型语言,自创始以来,现已具有将近20年的发展历史,其既成熟又稳定。随时人工智能时代的来临,Python作为AI的黄金编程语言,更是进一步被推向了高潮。
    Python语言的设计秉承的原则是“优雅”、“明确”、“简单”。比方说用这三门语言完成同一个任务,C语言要写1000行代码,Java只需要写100行,而Python可能只要10行或者20行就可以搞定。如此高效的语言,你值得拥有~~关于Python的介绍,小伙伴们可以阅读:Python、C 还是Java,零基础的小白想学习编程应该挑选哪门语言?
    学习Python需要明确的学习路线图,下面分别是Python网络爬虫和web方向需要学习的知识点。

    Python网络爬虫学习路线图
    Python网络爬虫学习涉及的内容主要有:Python入门知识、web前端知识、爬虫基础知识、爬虫进阶知识等等,一步一步循序渐进。每一个阶段学习到的知识都特色丰富,从简单到复杂。

    Python web方向学习路线图
    温馨提示:如果学习路线图看不清楚的话,可以给我留言,尔后我将私发给你~~
    Python web方向涉及的内容主要有:搭建环境、面向对象编程(OOP)、HTML知识、Django、Tornado、项目思想、多进程等等,同样的,每个学习阶段,都有大量的知识点等着我们去挖掘。

    学习过程是煎熬的,而且循序渐进。当你的基础部分学完了,之后你也肯定会忘记一部分,本自己以为掌握好的知识点,等到用时候发现自己还是不知道怎么用。不用慌,这个问题不大~~这是学习的必经之路,温故而知新,当你再回去复习基础知识,你会有更深入的认识(蓦然回首,那人却在灯火阑珊处)。我们都处于奋斗的时代,别因为小小困难而轻易放弃,学习更是要耐得住寂寞,不可急于求成。
    好了,今天的分享就到这里了,不知道大家有没有清晰了呢,小猿圈-IT自学人的小圈子,大家记得关注小猿圈哦,小猿圈回经常给大家分享一些干货知识的。

    展开全文
  • Python软件包包含一些类模块,在基于Python网络应用中使用。 注意:该存储库由GDS开发人员维护,但不由GOV.UK设计系统团队维护。 如果您有任何疑问或需要支持,请针对此存储库提出问题。 正在安装 pip install...
  • Flask是一个基于Python开发,依赖jinja2模板Werkzeug WSGI服务的一个微型框架。Werkzeug用来处理Socket服务,其在Flask中被用于接受处理http请求;Jinja2被用来对模板进行处理,将模板数据进行渲染,返回给...

    目录

    前言

    安装bootstrap扩展

    模板的继承

    总结


    前言

    Flask是一个基于Python开发,依赖jinja2模板和Werkzeug WSGI服务的一个微型框架。Werkzeug用来处理Socket服务,其在Flask中被用于接受和处理http请求,Jinja2被用来对模板进行处理,将模板和数据进行渲染,返回给用户的浏览器。

    Bootstrap是由Twitter推出的一个用于前端开发的开源工具包,给予HTML、CSS、JavaScriot,提供简洁、直观、强悍的前端开发框架。

    先看看几种流行的前端框架:BootStrap, React, Vue。

    • BootStrap容易上手,学习成本低,它提供了一些常用的css和js,拿来就能用。
    • React是数据单向响应的,数据发生变化时,前端UI即可随之变化。React可管理Dom树的变化,使页面呈现更快。
    • Vue站在了React的肩膀上, 许多方面更出色,如数据的双向绑定,速度更快,组件化,方便打包和发布等等,但相对来说上手的难度较大。

    长远考虑, 建议使用Vue+node.js. 短期简单使用,BootStrap是个不错的选择。因此在这里选择了Bootstrap。

    由于博主不是专门做这个的,所以下面的内容只是博主的一些理解和实际使用过程中的一些方法,并不能保证完全正确。

    安装bootstrap扩展

    pip install flask-bootstrap

    安装完成后,我们可以看到在 \venv\Lib\site-packages\flask_bootstrap\templates\bootstrap路径下,看到bootstrap的一些基础模板。

    直接通过浏览器打开,会看到html文本的内容,接下来需要将这些模板通过Flask 调用jinja2进行渲染(这一段为博主猜测)

    模板的继承

    在程序中,导入bootstrap并进行初始化

    from flask_bootstrap import Bootstrap  #python3.x导入方式
    from flask.ext.bootstrap import Bootstrap  #python2.x导入方式
    bootstrap=Bootstrap(app)

    在项目根目录的template目录中,创建html模板,并继承上文中bootstrap这个目录下的base.html

    采用继承的这种模式,我们便可以使用在base.html中定义好的块

    在app.py中,设置URL“/test”返回该test模板

    @app.route('/test')
    def test():
    return render_template('test.html')

    程序运行试一下:

    这时可以看到,网页中什么都没有,这是因为我们在test.html文件中,没有使用任何块

    我们看一下/bootstrap/base.html中有哪些块可以让我们使用:

    {% block doc -%}
    <!DOCTYPE html>
    <html{% block html_attribs %}{% endblock html_attribs %}>
    {%- block html %}
    <head>
    {%- block head %}
    <title>{% block title %}{{title|default}}{% endblock title %}</title>
    {%- block metas %}
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    {%- endblock metas %}
    {%- block styles %}
    <!-- Bootstrap -->
    <link href="{{bootstrap_find_resource('css/bootstrap.css', cdn='bootstrap')}}" rel="stylesheet">
    {%- endblock styles %}
    {%- endblock head %}
    </head>
    <body{% block body_attribs %}{% endblock body_attribs %}>
    {% block body -%}
    {% block navbar %}
    {%- endblock navbar %}
    {% block content -%}
    {%- endblock content %}
    {% block scripts %}
    <script src="{{bootstrap_find_resource('jquery.js', cdn='jquery')}}"></script>
    <script src="{{bootstrap_find_resource('js/bootstrap.js', cdn='bootstrap')}}"></script>
    {%- endblock scripts %}
    {%- endblock body %}
    </body>
    {%- endblock html %}
    </html>
    {% endblock doc -%}

    由此,我们可以看到,我们可以使用包括head、style、metas、body、navbar、content等等

    我们可以利用菜鸟教程网站的一些示例,尝试一下这些块的编写方法,

    我们可以试一下导航元素 网址如下:https://www.runoob.com/bootstrap/bootstrap-navigation-elements.html

    我们可以尝试,带有下拉菜单的标签页,复制菜鸟教程中的html代码,粘贴在{% block navbar %}{%- endblock navbar %}之间

    编辑test.html文件:

    {% extends "bootstrap/base.html" %}
    
    {% block title %}Flask{% endblock %}
    
    {% block navbar %}
    <p>带有下拉菜单的标签</p>
      <ul class="nav nav-tabs">
        <li class="active"><a href="#">Home</a></li>
        <li><a href="#">SVN</a></li>
        <li><a href="#">iOS</a></li>
        <li><a href="#">VB.Net</a></li>
        <li class="dropdown">
          <a class="dropdown-toggle" data-toggle="dropdown" href="#">
            Java <span class="caret"></span>
          </a>
          <ul class="dropdown-menu">
            <li><a href="#">Swing</a></li>
            <li><a href="#">jMeter</a></li>
            <li><a href="#">EJB</a></li>
            <li class="divider"></li>
            <li><a href="#">分离的链接</a></li>
          </ul>
        </li>
        <li><a href="#">PHP</a></li>
      </ul>
    
    {% endblock %}

    我们看一下效果:

    可以看到,这达到了我们想要的效果,依次类推,我们可以自己定义导航栏的内容,以及其他块的内容等等。

    我们可以结合bootstrap网站上的实际案例,定制我们自己想要的网页效果

    https://v3.bootcss.com/getting-started/#examples

    下面看一下我最终的代码与实现的效果

    {% extends "bootstrap/base.html"  %}
    {%- block head %}
        <title>网络自动化管理—欢迎页!</title>
        <meta charset="utf-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1">
        <!-- 上述3个meta标签*必须*放在最前面,任何其他内容都*必须*跟随其后! -->
        <meta name="description" content="">
        <meta name="author" content="">
        <link rel="icon" href="../../favicon.ico">
     
        {%- block styles %}
        <!-- Bootstrap -->
        <link href="{{bootstrap_find_resource('css/bootstrap.css', cdn='bootstrap')}}" rel="stylesheet">
            <!-- Bootstrap core CSS -->
    {#    <link href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet">#}
            <!-- bb——这里是通过下载网页上的css文件,保存在static目录下即可-->
        <link href="static/css/bootstrap.min.css" rel="stylesheet">
        <!-- Custom styles for this template -->
          <!-- bb——这里是通过下载网页上的css文件,保存在static目录下即可-->
        <link href="static/css/carousel.css" rel="stylesheet">
        {%- endblock styles %}
    {%- endblock head %}
    {% block body -%}
        {% block navbar %}
    <div class="navbar-wrapper">
          <div class="container">
     
            <nav class="navbar navbar-inverse navbar-static-top">
              <div class="container">
                <div class="navbar-header">
                  <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false" aria-controls="navbar">
                    <span class="sr-only">Toggle navigation</span>
                    <span class="icon-bar"></span>
                    <span class="icon-bar"></span>
                    <span class="icon-bar"></span>
                  </button>
                  <a class="navbar-brand" href="#">功能导航</a>
                </div>
                <div id="navbar" class="navbar-collapse collapse">
                  <ul class="nav navbar-nav">
                    <li class="active"><a href="/welcome">首页</a></li>
                    <li><a href="/InformationDispaly">信息展示</a></li>
                    <li><a href="/IndexCollect">信息收集</a></li>
                    <li><a href="/NetAutoRun">配置执行</a></li>
                    <li><a href="/contact">联系我</a></li>
    {#                <li class="dropdown">#}
    {#                  <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true" aria-expanded="false">Dropdown <span class="caret"></span></a>#}
    {#                  <ul class="dropdown-menu">#}
    {#                    <li><a href="#">Action</a></li>#}
    {#                    <li><a href="#">Another action</a></li>#}
    {#                    <li><a href="#">Something else here</a></li>#}
    {#                    <li role="separator" class="divider"></li>#}
    {#                    <li class="dropdown-header">Nav header</li>#}
    {#                    <li><a href="#">Separated link</a></li>#}
    {#                    <li><a href="#">One more separated link</a></li>#}
    {#                  </ul>#}
    {#                </li>#}
                  </ul>
                </div>
              </div>
            </nav>
     
          </div>
        </div>
     
        {%- endblock navbar %}
        {% block content -%}
            <div id="myCarousel" class="carousel slide" data-ride="carousel">
          <!-- Indicators -->
          <ol class="carousel-indicators">
            <li data-target="#myCarousel" data-slide-to="0" class="active"></li>
            <li data-target="#myCarousel" data-slide-to="1"></li>
            <li data-target="#myCarousel" data-slide-to="2"></li>
          </ol>
          <div class="carousel-inner" role="listbox">
            <div class="item active">
              <img class="first-slide" src="" alt="First slide">
              <div class="container">
                <div class="carousel-caption">
                  <h1>CCIE的转变由此开始</h1>
    {#              <p>Note: If you're viewing this page via a <code>file://</code> URL, the "next" and "previous" Glyphicon buttons on the left and right might not load/display properly due to web browser security rules.</p>#}
                  <p>这是一个完全由一名网络工程师独立建立的网站</p>
                  <p>如果你也是一名网络工程师,并同样期待改变,你可以从这里开始</p>
                  <p><a class="btn btn-lg btn-primary" href="https://blog.csdn.net/sinat_17736151" role="button">我的CSDN博客</a></p>
                </div>
              </div>
            </div>
            <div class="item">
              <img class="second-slide" src="" alt="Second slide">
              <div class="container">
                <div class="carousel-caption">
                  <h1>One Step</h1>
                  <p>首先,你应该构建符合自身职业规划的技术能力栈</p>
                  <p>如果你也是一名网络工程师,你可以参考我的想法</p>
                  <p><a class="btn btn-lg btn-primary" href="/stack" role="button">Learn more</a></p>
                </div>
              </div>
            </div>
            <div class="item">
              <img class="third-slide" src="" alt="Third slide">
              <div class="container">
                <div class="carousel-caption">
                  <h1>Move on</h1>
                  <p>在这里,你可以看到我下一步的规划和打算</p>
                  <p>或许能够对你有所帮助</p>
                  <p><a class="btn btn-lg btn-primary" href="#" role="button">Learn more</a></p>
                </div>
              </div>
            </div>
          </div>
          <a class="left carousel-control" href="#myCarousel" role="button" data-slide="prev">
            <span class="glyphicon glyphicon-chevron-left" aria-hidden="true"></span>
            <span class="sr-only">Previous</span>
          </a>
          <a class="right carousel-control" href="#myCarousel" role="button" data-slide="next">
            <span class="glyphicon glyphicon-chevron-right" aria-hidden="true"></span>
            <span class="sr-only">Next</span>
          </a>
        </div><!-- /.carousel -->
     
                <div class="container marketing">
     
          <!-- Three columns of text below the carousel -->
          <div class="row">
            <div class="col-lg-4">
              <img class="img-circle" src="" alt="Generic placeholder image" width="140" height="140">
              <h2>信息展示</h2>
              <p>提供网络运维相关信息的展示;目前可提供IP地址查询、负载均衡对应关系查询、域名对应关系查询等</p>
              <p><a class="btn btn-default" href="#" role="button">View details &raquo;</a></p>
            </div><!-- /.col-lg-4 -->
            <div class="col-lg-4">
              <img class="img-circle" src="" alt="Generic placeholder image" width="140" height="140">
              <h2>信息收集</h2>
              <p>针对未进行集中统计的信息,提供定制化信息收集的功能;可提供设备配置收集、设备接口指标定期收集、设备性能指标定期收集、设备日志收集等功能</p>
              <p><a class="btn btn-default" href="#" role="button">View details &raquo;</a></p>
            </div><!-- /.col-lg-4 -->
            <div class="col-lg-4">
              <img class="img-circle" src="" alt="Generic placeholder image" width="140" height="140">
              <h2>配置执行</h2>
              <p>可针对网络设备,批量下发相关配置;该功能目前主要针对分行、网点、楼层网络设备开放</p>
              <p><a class="btn btn-default" href="#" role="button">View details &raquo;</a></p>
            </div><!-- /.col-lg-4 -->
          </div><!-- /.row -->
     
        {%- endblock content %}
     
    {% block scripts %}
        <script src="{{bootstrap_find_resource('jquery.js', cdn='jquery')}}"></script>
        <script src="{{bootstrap_find_resource('js/bootstrap.js', cdn='bootstrap')}}"></script>
         <!-- Bootstrap core JavaScript
        ================================================== -->
        <!-- Placed at the end of the document so the pages load faster -->
    {#    <script src="https://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>#}
        <script src="/static/js/jquery.min.js"></script>
     
        <script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
    {#    <script src="https://cdn.bootcss.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>#}
        <script src="/static/js/bootstrap.min.js"></script>
     
     
    {%- endblock scripts %}
     
    {%- endblock body %}

    总结

    通过这篇文章,我们掌握到了基本的如何利用Bootstrap框架,快速高效的设计我们的网页。

    展开全文
  • 最近很多小伙伴找小编咨询,如何系统的学习Python?相信这个论题应该困扰了许多想学习Python的人,今天小编给大家讲一下一个零根底的小白,应该如何体系化的学习Python编程...如果你前端和后端都搞得定,那么恭喜...

    王者程序员整理的Python网络爬虫和web的系统学习路线图

    最近很多小伙伴找小编咨询,如何系统的学习Python?相信这个论题应该困扰了许多想学习Python的人,今天小编给大家讲一下一个零根底的小白,应该如何体系化的学习Python编程语言,在学习的道路上少浪费时间去摸索,少走弯路。

    相信小伙伴们都知道,目前Python主打的两个方向:其一是网络爬虫,其二是web开发。如果将这两者完美的结合起来,可以说是天作之合。如果你前端和后端都搞得定,那么恭喜你,全栈工程师的这份殊荣是你的了。

    王者程序员整理的Python网络爬虫和web的系统学习路线图

    那么为什么要学习Python呢?Python是一种面向对象的计算机程序设计语言,也是一种功能强大,而且完善的通用型语言,自创始以来,现已具有将近20年的发展历史,其既成熟又稳定。随时人工智能时代的来临,Python作为AI的黄金编程语言,更是进一步被推向了高潮。

    Python语言的设计秉承的原则是“优雅”、“明确”、“简单”。比方说用这三门语言完成同一个任务,C语言要写1000行代码,Java只需要写100行,而Python可能只要10行或者20行就可以搞定。如此高效的语言,你值得拥有~~关于Python的介绍,小伙伴们可以阅读:Python、C 还是Java,零基础的小白想学习编程应该挑选哪门语言?

    学习Python需要明确的学习路线图,下面分别是Python网络爬虫和web方向需要学习的知识点。

    王者程序员整理的Python网络爬虫和web的系统学习路线图

    Python网络爬虫学习路线图

    Python网络爬虫学习涉及的内容主要有:Python入门知识、web前端知识、爬虫基础知识、爬虫进阶知识等等,一步一步循序渐进。每一个阶段学习到的知识都特色丰富,从简单到复杂。

    王者程序员整理的Python网络爬虫和web的系统学习路线图

    Python web方向学习路线图

    温馨提示:如果学习路线图看不清楚的话,可以在评论区留言哈~~

    Python web方向涉及的内容主要有:搭建环境、面向对象编程(OOP)、HTML知识、Django、Tornado、项目思想、多进程等等,同样的,每个学习阶段,都有大量的知识点等着我们去挖掘。

    王者程序员整理的Python网络爬虫和web的系统学习路线图

    学习过程是煎熬的,而且循序渐进。当你的基础部分学完了,之后你也肯定会忘记一部分,本自己以为掌握好的知识点,等到用时候发现自己还是不知道怎么用。不用慌,这个问题不大~~这是学习的必经之路,温故而知新,当你再回去复习基础知识,你会有更深入的认识(蓦然回首,那人却在灯火阑珊处)。我们都处于奋斗的时代,别因为小小困难而轻易放弃,学习更是要耐得住寂寞,不可急于求成。

    Stay hungry, stay foolish~我们都知道目前Python正当红,学好Python对日后的发展肯定有帮助,人生苦短,让Python来助力你的高薪人生吧!

    展开全文
  • 如何系统的学习Python?相信这个论题应该困扰了许多想学习Python的人,今天给大家讲一下一个零根底的小白,应该如何体系化的学习Python编程...如果你前端和后端都搞得定,那么恭喜你,全栈工程师的这份殊荣是你的...
  • 前端是使用HTML,CSS,JavaScript(jQuery)Bootstrap构建的。 发展 设置:,然后运行pip install -r requirements.txt安装所有依赖项。 开发:要启动服务器,请运行python -m flask run 。 逛一圈! 查看一组 ...
  • 前言 在若干次前的一场面试,面试官看我做过python爬虫/后端 的工作,顺带问了我些后端相关的问题...无论你的动机是什么,这个体系里都有你想要了解或学习的东西: 存储服务如何结合在一起? 什么时候(或为什么)我
  • 一、融汇贯通 将Python语言Django基础知识,以实际应用为媒介,有机组织、融汇贯通。让你的理论与实践结合起来,由知道变成会用。使用了大量的Django高级特性Bootstrap前端框架,展示了真实的项目部署过程。 &...
  • 一、融汇贯通 将Python语言Django基础知识,以实际应用为媒介,有机组织、融汇贯通。让你的理论与实践结合起来,由知道变成会用。使用了大量的Django高级特性Bootstrap前端框架,展示了真实的项目部署过程。 二...
  • 1、具有一定Python语言基础,有一定的web前端基础,想要深入学习Python Web框架的朋友; 2、学习完“跟着王进老师学开发Python篇”“跟着王进老师学Web前端开发”的朋友; 3、有Django基础,但是想学习企业级项目...
  • Flask是一个基于Python开发,依赖jinja2模板Werkzeug WSGI服务的一个微型框架。Werkzeug用来处理Socket服务,其在Flask中被用于接受处理http请求;Jinja2被用来对模板进行处理,将模板数据进行渲染,返回给...
  • 在若干次前的一场面试,面试官看我做过python爬虫/后端 的工作,顺带问了我些后端相关的问题:你觉得什么是后端? 送命题。当时脑瓦特了,答曰:逻辑处理数据增删改查。。。 当场被怼得体无完肤,羞愧难当。事后...
  • Flask是一个给予Python开发,依赖jinja2模板Werkzeug WSGI服务的一个微型框架。Werkzeug用来处理Socket服务,其在Flask中被用于接受处理http请求;Jinja2被用来对模板进行处理,将模板数据进行渲染,返回给...
  • 由于接口的编写框架使用的是flask框架(Flask框架Django框架是两个比较常用的web框架),Flak框架官网解释是一个轻量级的Web应用框架,而Django框架官网的解释是高水准(重量级)的Python编程语言驱动的一个开源...
  • 我正在使用它来将Python后端与React前端结合起来,但是如果您更喜欢使用Flask来处理您的前端,那应该很容易做到。 Electron主(后端)过程产生一个Python Flask Web服务器,并向Web服务器Electron渲染器(前端)...
  • Python 面试不仅需要掌握 Python 基础知识高级语法,还会涉及网络编程、web 前端后端、数据库、网络爬虫、数据解析、数据分析数据可视化等各方面的核心知识。针对网上资料参差不齐,并且自己上网寻找费时费力,...
  • 初入python数据分析

    2019-12-27 16:48:36
    虽然只会一个数据分析找工作会比较困难,但是结合以往所学的python爬虫或者web前端绑在一起会更加加分,也可以突出自己的能力 是python数据科学的基础 当面对庞大的数据量时,仅仅使用python和数据库的语法就...
  • 测试网站后端和前端数据接口对接 Selenium是一个Web的自动化测试工具,最初是为网站自动化测试而开发的,类型像我们玩游戏用的按键精灵,可以按指定的命令自动操作,不同是Selenium 可以直接运行在浏览器上,它支持...

空空如也

空空如也

1 2 3 4 5 ... 8
收藏数 143
精华内容 57
关键字:

python和web前端结合

python 订阅