UI设计实战篇——利用Bootstrap框架制作查询页面的界面

本文涉及的产品
对象存储 OSS,标准 - 本地冗余存储 20GB 3个月
对象存储OSS,敏感数据保护2.0 200GB 1年
对象存储 OSS,恶意文件检测 1000次 1年
简介: Bootstrap框架是一个前端UI设计的框架,它提供了统一的UI界面,简化了设计界面UI的过程(缺点是定制了界面,调整的余地不是太大)。尤其是现在的响应时布局(我的理解是页面根据不同的分辨率,采用不同的页面元素的布局),在Bootstrap中很好的支持了,只要简单设置了属性,就能自动实现响应时布局,大大简化了程序员的界面的过程。

Bootstrap框架是一个前端UI设计的框架,它提供了统一的UI界面,简化了设计界面UI的过程(缺点是定制了界面,调整的余地不是太大)。尤其是现在的响应时布局(我的理解是页面根据不同的分辨率,采用不同的页面元素的布局),在Bootstrap中很好的支持了,只要简单设置了属性,就能自动实现响应时布局,大大简化了程序员的界面的过程。

 

因此,本人用Bootstrap框架实现了如下的界面,虽然简单,但也不凡(真要自己实现的话,不知要猴年马月了)

1

 

 

整个页面分为几个部分,分别用Bootstrap官网上的示例代码实现,最终拼成一个页面。各部分示意如下图所示

 

2

 

接下来依次讲解各个部分的代码

 

首先,构造空白页面,代码如下:

 

<! DOCTYPE  html >
    < html  lang ="en">
    < head >
        < meta  charset ="utf-8">
        < meta  http-equiv ="X-UA-Compatible"  content ="IE=edge">
        < meta  name ="viewport"  content ="width=device-width, initial-scale=1.0">
        < meta  name ="description"  content ="">
        < meta  name ="author"  content ="">
    
        < title >职业技能考证分数查询(Bootstrap) </ title >

        < link  rel ="stylesheet"  href ="http://cdn.bootcss.com/twitter-bootstrap/3.0.1/css/bootstrap.min.css">
        < link  rel ="stylesheet"  href ="http://cdn.bootcss.com/twitter-bootstrap/3.0.1/css/bootstrap-theme.min.css">

        <!--[if lt IE 9]><script src="../../docs-assets/js/ie8-responsive-file-warning.js"></script><![endif]-->
        <!--[if lt IE 9]>
            <script src="https://oss.maxcdn.com/libs/html5shiv/3.7.0/html5shiv.js"></script>
            <script src="https://oss.maxcdn.com/libs/respond.js/1.3.0/respond.min.js"></script>
        <![endif]-->
    
        < style >
            .bs-docs-home
            {
            background-color: #1B31B1;
            background-image: url(line.png);
            }
    </ style >
</ head >

< body  class ="bs-docs-home"> 

    < script  src ="https://code.jquery.com/jquery-1.10.2.min.js"></ script >
    < script  src ="http://cdn.bootcss.com/twitter-bootstrap/3.0.1/js/bootstrap.min.js"></ script >
</ body >
</ html >

 

要想使用Bootstrap框架,就要在页面中引用Bootstrap框架文件。一共四个:bootstrap.min.css、bootstrap-theme.min.css、jquery-1.10.2.min.js、bootstrap.min.js

只有引用了这些文件,接下来才可以使用Bootstrap框架提供的各种UI元素

接下来按照上图依次说明各个部分的代码

 

 

顶部说明文字:

 

设计整个页面的思路是整个页面放在一个面板(Panel)上,顶部的说明的文字就是面板头(Panel Head)

而Bootstrap框架的页面是一个12列的网格布局。因此,我把整个页面分成三部分。左右各3列宽的空白,中间6列宽放一个面板(Panel)。

代码如下:剩下部分的代码都依次在<div class="panel-body"> </div>

 

< body  class ="bs-docs-home">
    < div  class ="container theme-showcase">
        < h1  style =" line-height :2em;">  </ h1 >< br  />
      
        < div  class ="row">
            < div  class ="col-sm-3"></ div >

            < div  class ="col-sm-6">
                < div  class ="panel panel-primary">
                    < div  class ="panel-heading">
                        < h3  class ="panel-title">< strong >职业技能考证分数查询 </ strong ></ h3 >
                    </ div >
                    < div  class ="panel-body"> 

                    </ div > 
                </ div > 
            </ div > 
      
            < div  class ="col-sm-3"></ div > 
        </ div >
    </ div > 
    < script  src ="https://code.jquery.com/jquery-1.10.2.min.js"></ script >
    < script  src ="http://cdn.bootcss.com/twitter-bootstrap/3.0.1/js/bootstrap.min.js"></ script >
</ body >

 

 

提示文字

提示文字用的是Bootstrap框架中的提示(alert)组件,代码如下:

 

  < div  class ="alert alert-danger alert-dismissable"> 
      < button  type ="button"  class ="close"  data-dismiss ="alert"  aria-hidden ="true"> &times; </ button > 
      < strong >注意! </ strong > 本站查询的分数来源于12333官网,详情请到官网咨询
  </ div > 
 

 

身份证表单和查询按钮

身份证表单和后面的科目表单都应该在一个表单中。身份证表单和查询按钮是利用Bootstrap框架的表单元素组。利用input group把文本框(input)和按钮(button)组合在一起。而Bootstrap框架提供了诸如水印、高亮等效果。为表单增色不少

 

    < form  role ="form"  name ="form1"> 

        < div  class ="form-group"> 
            < label  for ="IDCard">请输入您的身份证号码 </ label > 
            < div  class ="input-group"> 
                < input  type ="text"  class ="form-control"  id ="IDCard"  name ="IDCard"  placeholder ="身份证号码"  > 
                < span  class ="input-group-btn"> 
                    < button  class ="btn btn-default"  type ="button"  onClick ="form1.submit();"  >查询 </ button > 
                </ span > 
            </ div > 
        </ div > 
      
    </ form > 
           

科目表单

科目表单也是利用Bootstrap框架的表单元素组。利用input group把文本框(input)和按钮(button)和下拉列表(ul)组合在一起。

可以在文本框里直接输入科目,也可以在下拉菜单中选择科目。具体的实现是在超链接(a)的点击事件(click)中用$('#Subject').val('计算机操作员')等代码来改变文本框中的内容。科目表单位置在身份证表单的下方,在表单(form)里面

 

代码如下:

         
     <div class="form-group"> 
         <label for="Subject">请输入您要查询的科目</label> 
         <div class="input-group"> 
             <input type="text" class="form-control" id="Subject" name="Subject" placeholder="科目,空白科目意味着查询所有的科目" > 
             <div class="input-group-btn"> 
                 <button type="button" class="btn btn-default dropdown-toggle" data-toggle="dropdown">科目 <span class="caret"></span></button> 
                 <ul class="dropdown-menu pull-right"> 
                     <li><a href="#" onClick="$('#Subject').val('计算机操作员');">计算机操作员</a></li> 
                     <li><a href="#" onClick="$('#Subject').val('网页设计');">网页设计</a></li> 
                     <li><a href="#" onClick="$('#Subject').val('多媒体');">多媒体</a></li> 
                 </ul> 
             </div> 
         </div> 
     </div> 
      

查询错误信息

当点击查询按钮时,没有查到记录的时候,则显示该查询错误信息。和之前的提示文字一样,用的是Bootstrap框架中的提示(alert)组件。

这个信息是否显示,还需要后台动态代码的配合,动态代码根据查询的结果来决定是否显示该信息(没有记录,则显示该信息)。动态代码不在这篇文章里讨论。

位置在表单(form)的后面,代码如下:

            
    <div class="alert alert-danger alert-dismissable"> 
        <button type="button" class="close" data-dismiss="alert" aria-hidden="true">&times;</button> 
        <strong>注意!</strong> 没有查到成绩,请检查身份证号码和科目后,再次查询 
   </div>  
            

成绩表格

当点击查询按钮时,查到记录的时候,则显示成绩表格。同样,是否显示也需要后台的动态代码的配合。

查询错误信息和成绩表格同时只能出现一个

代码如下:

 

    < div  class ="table-responsive"> 
        < table  border ="0"  cellspacing ="0"  cellpadding ="0"  class ="table"> 
            < tr  class =" label-primary"> 
                < th  scope ="col"  width ="50%"  >< span  style =" color :white">科目 </ span ></ th > 
                < th  scope ="col">< span  style =" color :white">成绩 </ span ></ th > 
            </ tr > 
            < tr  class ="active"> 
                < td >计算机操作员 </ td > 
                < td >没有成绩 </ td > 
            </ tr > 
            < tr  class ="success"> 
                < td >计算机操作员 </ td > 
                < td >优秀 </ td > 
            </ tr > 
            < tr  class ="active"> 
                < td >多媒体操作员 </ td > 
                < td >良好 </ td > 
            </ tr > 
            < tr  class ="success"> 
                < td >网页设计 </ td > 
                < td >不及格 </ td > 
            </ tr >  
        </ table > 
    </ div >          
   

 

这个页面是利用Bootstrap框架来实现的,得益于Bootstrap框架的强大,使得设计UI不再成为一件难事。但Bootstrap仅仅是UI框架,它的出彩还得依靠后台的动态代码的配合。

下面这个网址,就是笔者用上面的界面加上后台动态代码(PHP)来实现职业技能考试分数(仅限于上海)的查询的功能。大家可以去看看,并提出宝贵的意见(有效期1个月)。

http://bertin.sturgeon.mopaas.com/

image

 

 

 

完整的UI代码如下:

 

<! DOCTYPE  html >
    < html  lang ="en">
    < head >
        < meta  charset ="utf-8">
        < meta  http-equiv ="X-UA-Compatible"  content ="IE=edge">
        < meta  name ="viewport"  content ="width=device-width, initial-scale=1.0">
        < meta  name ="description"  content ="">
        < meta  name ="author"  content ="">
    
        < title >职业技能考证分数查询(Bootstrap) </ title >

        < link  rel ="stylesheet"  href ="http://cdn.bootcss.com/twitter-bootstrap/3.0.1/css/bootstrap.min.css">
        < link  rel ="stylesheet"  href ="http://cdn.bootcss.com/twitter-bootstrap/3.0.1/css/bootstrap-theme.min.css">

        <!--[if lt IE 9]><script src="../../docs-assets/js/ie8-responsive-file-warning.js"></script><![endif]-->
        <!--[if lt IE 9]>
            <script src="https://oss.maxcdn.com/libs/html5shiv/3.7.0/html5shiv.js"></script>
            <script src="https://oss.maxcdn.com/libs/respond.js/1.3.0/respond.min.js"></script>
        <![endif]-->
    
        < style >
            .bs-docs-home
            {
            background-color: #1B31B1;
            background-image: url(line.png);
            }
    </ style >
</ head >

< body  class ="bs-docs-home">
    < div  class ="container theme-showcase">
        < h1  style =" line-height :2em;">  </ h1 >< br  />
      
        < div  class ="row">
            < div  class ="col-sm-3"></ div >
        < div  class ="col-sm-6">
            < div  class ="panel panel-primary">
                < div  class ="panel-heading">
                    < h3  class ="panel-title">< strong >职业技能考证分数查询 </ strong ></ h3 >
                </ div >
                < div  class ="panel-body">
                   < div  class ="alert alert-danger alert-dismissable">
                       < button  type ="button"  class ="close"  data-dismiss ="alert"  aria-hidden ="true"> &times; </ button >
                       < strong >注意! </ strong > 本站查询的分数来源于12333官网,详情请到官网咨询 </ div >
              
                       < form  role ="form"  name ="form1">

                           < div  class ="form-group">
                               < label  for ="IDCard">请输入您的身份证号码 </ label >
                               < div  class ="input-group">
                                   < input  type ="text"  class ="form-control"  id ="IDCard"  name ="IDCard"  placeholder ="身份证号码"  >
                                   < span  class ="input-group-btn">
                                       < button  class ="btn btn-default"  type ="button"  onClick ="form1.submit();"  >查询 </ button >
                                   </ span >
                               </ div >
                           </ div >
        
                           < div  class ="form-group">
                               < label  for ="Subject">请输入您要查询的科目 </ label >
                               < div  class ="input-group">
                                   < input  type ="text"  class ="form-control"  id ="Subject"  name ="Subject"  placeholder ="科目,空白科目意味着查询所有的科目"  >
                                   < div  class ="input-group-btn">
                                       < button  type ="button"  class ="btn btn-default dropdown-toggle"  data-toggle ="dropdown">科目 < span  class ="caret"></ span ></ button >
                                       < ul  class ="dropdown-menu pull-right">
                                           < li >< a  href ="#"  onClick ="$('#Subject').val('计算机操作员');">计算机操作员 </ a ></ li >
                                           < li >< a  href ="#"  onClick ="$('#Subject').val('网页设计');">网页设计 </ a ></ li >
                                           < li >< a  href ="#"  onClick ="$('#Subject').val('多媒体');">多媒体 </ a ></ li >
                                       </ ul >
                                   </ div >
                               </ div >
                           </ div >
      
                       </ form >
           
                       < div  class ="alert alert-danger alert-dismissable">
                           < button  type ="button"  class ="close"  data-dismiss ="alert"  aria-hidden ="true"> &times; </ button >
                           < strong >注意! </ strong > 没有查到成绩,请检查身份证号码和科目后,再次查询
                       </ div > 
            
                       < div  class ="table-responsive">
                           < table  border ="0"  cellspacing ="0"  cellpadding ="0"  class ="table">
                               < tr  class =" label-primary">
                                   < th  scope ="col"  width ="50%"  >< span  style =" color :white">科目 </ span ></ th >
                                   < th  scope ="col">< span  style =" color :white">成绩 </ span ></ th >
                               </ tr >
                               < tr  class ="active">
                                   < td  width ="50%">计算机操作员 </ td >
                                   < td >没有成绩 </ td >
                               </ tr >
                               < tr  class ="success">
                                   < td >计算机操作员 </ td >
                                   < td >优秀 </ td >
                               </ tr >
                               < tr  class ="active">
                                   < td >多媒体操作员 </ td >
                                   < td >良好 </ td >
                               </ tr >
                               < tr  class ="success">
                                   < td >网页设计 </ td >
                                   < td >不及格 </ td >
                               </ tr > 
                           </ table >
                       </ div >         
                   </ div >
               </ div >
           </ div >
     
           < div  class ="col-sm-3"></ div >
        </ div >
    </ div > 
    < script  src ="https://code.jquery.com/jquery-1.10.2.min.js"></ script >
    < script  src ="http://cdn.bootcss.com/twitter-bootstrap/3.0.1/js/bootstrap.min.js"></ script >
</ body >
</ html >

 

相关文章
|
1月前
|
前端开发 算法 Java
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
伪类:伪类这个叫法源自于它们跟类相似,但实际上并没有类会附加到标记中的标签上。 伪类分为两种(以及新增的伪类选择器): UI伪类:会在HTML元素处于某种状态时(例如:鼠标指针位于连接上),为该元素应用CSS样式。 :hover 结构化伪类:会在标记中存在某种结构上的关系时 例如: 某元素是一组元素中的第一个或最后一个,为该元素应用CSS样式。 :not和:target(CSS3新增的两个特殊的伪类选择器)
129 1
|
2月前
|
Web App开发 前端开发 JavaScript
Playwright极速UI自动化实战指南
Playwright告别Selenium痛点,以智能等待、强大选择器、网络拦截与多设备模拟四大利器,提升自动化效率与稳定性。本文通过实战代码详解其加速秘籍,助你构建高效、可靠的UI测试方案。
|
1月前
|
人工智能 自然语言处理 JavaScript
Playwright MCP在UI回归测试中的实战:构建AI自主测试智能体
Playwright MCP结合AI智能体,革新UI回归测试:通过自然语言驱动浏览器操作,降低脚本编写门槛,提升测试效率与覆盖范围。借助快照解析、智能定位与Jira等工具集成,实现从需求描述到自动化执行的闭环,推动测试迈向智能化、民主化新阶段。
|
2月前
|
存储 消息中间件 人工智能
【04】AI辅助编程完整的安卓二次商业实战-寻找修改替换新UI首页图标-菜单图标-消息列表图标-优雅草伊凡
【04】AI辅助编程完整的安卓二次商业实战-寻找修改替换新UI首页图标-菜单图标-消息列表图标-优雅草伊凡
114 4
|
2月前
|
JavaScript 前端开发 开发者
鸿蒙应用开发从入门到实战(六):ArkTS声明式UI和组件化
鸿蒙开发语言ArkTS在继承了Typescrip语法的基础上,主要扩展了声明式UI开发相关的能力。
127 1
|
3月前
|
传感器 人工智能 JavaScript
Playwright实战:写UI自动化脚本,速度直接起飞
简介: 测试工程师老王因UI自动化问题深夜奋战,反映出传统测试工具的局限性。微软开源的Playwright凭借智能等待、跨域操作、移动端模拟与网络拦截等强大功能,正迅速取代Selenium,成为新一代自动化测试标准。其稳定高效的设计显著降低维护成本,助力企业构建高质量测试流程。
|
9月前
|
前端开发 安全 开发工具
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
556 90
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
存储 JavaScript 开发者
探索鸿蒙新世界:ArkUI框架实战指南,解锁HarmonyOS应用UI设计的无限可能!
【10月更文挑战第19天】ArkUI框架是华为鸿蒙系统中用于开发用户界面的核心工具,支持ArkTS和eTS两种开发语言。本文介绍了ArkUI的基本概念、组件使用、布局管理和状态管理,通过示例代码帮助开发者轻松构建美观、高效的跨设备UI。
1031 3
|
9月前
|
存储 人工智能 编译器
【03】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-测试hello word效果-虚拟华为手机真机环境调试-为DevEco Studio编译器安装中文插件-测试写一个滑动块效果-介绍诸如ohos.ui等依赖库-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
【03】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-测试hello word效果-虚拟华为手机真机环境调试-为DevEco Studio编译器安装中文插件-测试写一个滑动块效果-介绍诸如ohos.ui等依赖库-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
511 10
【03】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-测试hello word效果-虚拟华为手机真机环境调试-为DevEco Studio编译器安装中文插件-测试写一个滑动块效果-介绍诸如ohos.ui等依赖库-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
|
机器学习/深度学习 数据采集 数据可视化
基于爬虫和机器学习的招聘数据分析与可视化系统,python django框架,前端bootstrap,机器学习有八种带有可视化大屏和后台
本文介绍了一个基于Python Django框架和Bootstrap前端技术,集成了机器学习算法和数据可视化的招聘数据分析与可视化系统,该系统通过爬虫技术获取职位信息,并使用多种机器学习模型进行薪资预测、职位匹配和趋势分析,提供了一个直观的可视化大屏和后台管理系统,以优化招聘策略并提升决策质量。
810 4

热门文章

最新文章