简介

网页开发中,CSS控制网页样式。作为测试开发工程师,我个人不太擅长手写CSS、样式微调、兼容浏览器等工作,所以我选择使用成熟的前端框架,可以快速开发出样式美观的网站,也解决了大部分浏览器兼容问题。前端框架百花齐放,我们公司的产品使用了Bootstrap,我个人使用的是Semantic UI。

安装Semantic UI

首先需要安装node、全局安装gulp(我使用的是Mac环境):

  • brew install node
  • sudo npm install -g gulp

然后进入项目的静态文件目录,比如我的是/learnflask/static,执行npm install semantic-ui --save,进行一些Semantic UI的设置后,安装完成(我设置的Semantic UI目录是/learnflask/static/semantic)后cd到Semantic UI目录,执行gulp build命令。

使用Semantic UI

使用Semantic UI,只需要在HTML文件头部引入如下3个文件即可(使用了又拍云的jQuery的CDN):

<script src="http://upcdn.b0.upaiyun.com/libs/jquery/jquery-2.0.2.min.js"></script>
<link rel="stylesheet" type="text/css" href="semantic/dist/semantic.min.css">
<script src="semantic/dist/semantic.min.js"></script

按钮

学习前端框架无非是学习其各个组件,我们先从按钮开始。

标准按钮

<button type="button" class="ui button">Click</button>

样式如下: 

除了<button>标签外,<div>标签也可以创建按钮(样式同上):

<div class="ui button" tabindex="0">Click</div>

优先级按钮

 <button type="button" class="ui primary button">Primary</button>
<button type="button" class="ui secondary button">Secondary</button>

样式如下: 

动画效果按钮

水平切换

<div class="ui animated button" tabindex="0">
<div class="visible content">下一步</div>
<div class="hidden content">
<i class="right arrow icon"></i>
</div>
</div>

样式如下: 

垂直切换

<div class="ui vertical animated button" tabindex="0">
<div class="visible content">购物车</div>
<div class="hidden content">
<i class="shop icon"></i>
</div>
</div>

样式如下: 

淡入淡出

<div class="ui fade animated button">
<div class="visible content">购买</div>
<div class="hidden content">&yen;12.9/月</div>
</div>

样式如下: 

空心按钮

<button class="ui basic button">
<i class="user icon"></i> 个人信息
</button>

样式如下:

阴性、阳性按钮

<button class="ui positive button">Positive</button>
<button class="ui negative button">Negative</button>

样式如下: 

不同颜色的按钮

 <button class="ui red basic button">Red</button>
<button class="ui orange basic button">Orange</button>
<button class="ui yellow basic button">Yellow</button>
<button class="ui olive basic button">Olive</button>
<button class="ui green basic button">Green</button>
<button class="ui teal basic button">Teal</button>
<button class="ui blue basic button">Blue</button>
<button class="ui violet basic button">Violet</button>
<button class="ui purple basic button">Purple</button>
<button class="ui pink basic button">Pink</button>
<button class="ui brown basic button">Brown</button>
<button class="ui grey basic button">Grey</button>
<button class="ui black basic button">Black</button>
<button class="ui red button">Red</button>
<button class="ui orange button">Orange</button>
<button class="ui yellow button">Yellow</button>
<button class="ui olive button">Olive</button>
<button class="ui green button">Green</button>
<button class="ui teal button">Teal</button>
<button class="ui blue button">Blue</button>
<button class="ui violet button">Violet</button>
<button class="ui purple button">Purple</button>
<button class="ui pink button">Pink</button>
<button class="ui brown button">Brown</button>
<button class="ui grey button">Grey</button>
<button class="ui black button">Black</button>

样式如下: 

反转色按钮

 <div class="ui inverted segment">
<button class="ui inverted button">Standard</button>
<button class="ui inverted red button">Red</button>
<button class="ui inverted orange button">Orange</button>
<button class="ui inverted yellow button">Yellow</button>
<button class="ui inverted olive button">Olive</button>
<button class="ui inverted green button">Green</button>
<button class="ui inverted teal button">Teal</button>
<button class="ui inverted blue button">Blue</button>
<button class="ui inverted violet button">Violet</button>
<button class="ui inverted purple button">Purple</button>
<button class="ui inverted pink button">Pink</button>
<button class="ui inverted brown button">Brown</button>
<button class="ui inverted grey button">Grey</button>
<button class="ui inverted black button">Black</button>
</div>
<div class="ui inverted segment">
<button class="ui inverted basic button">Basic</button>
<button class="ui inverted red basic button">Basic Red</button>
<button class="ui inverted orange basic button">Basic Orange</button>
<button class="ui inverted yellow basic button">Basic Yellow</button>
<button class="ui inverted olive basic button">Basic Olive</button>
<button class="ui inverted green basic button">Basic Green</button>
<button class="ui inverted teal basic button">Basic Teal</button>
<button class="ui inverted blue basic button">Basic Blue</button>
<button class="ui inverted violet basic button">Basic Violet</button>
<button class="ui inverted purple basic button">Basic Purple</button>
<button class="ui inverted pink basic button">Basic Pink</button>
<button class="ui inverted brown basic button">Basic Brown</button>
<button class="ui inverted grey basic button">Basic Grey</button>
<button class="ui inverted black basic button">Basic Black</button>
</div>

样式如下: 

带图标的按钮

<div class="ui icon button">
<i class="cloud icon"></i> 云存储
</div>

样式如下: 

表示状态的按钮

激活状态

<button class="ui active button"><i class="user icon"></i>Logged In</button>

样式如下: 

不可点击的按钮

<button class="ui disabled button"><i class="user icon"></i>Disabled</button>

样式如下: 

加载状态按钮

<button class="ui loading button">加载中...</button>

样式如下: 

表示状态切换的按钮

样式如下:

带标签的按钮

默认标签在右侧

<div class="ui labeled button" tabindex="0">
<div class="ui button">
<i class="heart icon"></i>
Like
</div>
<a class="ui basic label">
2,048
</a>
</div>

样式如下: 

标签在左侧且带向右的箭头(蓝色实心)

<div class="ui left labeled button" tabindex="0">
<a class="ui blue right pointing basic label">1,024</a>
<div class="ui blue icon button">
<i class="fork icon"></i> Forks
</div>
</div>

样式如下: 

标签为图标的按钮

<button class="ui labeled icon button">
<i class="pause icon"></i> Pause
</button>
<button class="ui right labeled icon button">
<i class="right arrow icon"></i> Next
</button>
样式如下: 

按钮分组

普通按钮分组

可以为组设置统一的颜色:

<div class="ui blue buttons">
<button class="ui button active">One</button>
<button class="ui button">Two</button>
</div>

样式如下: 

还可以设置其他属性,比如按钮大小、是否空心等等。

垂直显示的分组

可以设置整个组为空心按钮:

<div class="ui basic vertical buttons">
<button class="ui button active">One</button>
<button class="ui button">Two</button>
</div>

样式如下: 

图标按钮分组

<div class="ui icon buttons">
<button class="ui button"><i class="align left icon"></i></button>
<button class="ui button"><i class="align center icon"></i></button>
<button class="ui button"><i class="align right icon"></i></button>
<button class="ui button"><i class="align justify icon"></i></button>
</div>
<div class="ui icon buttons">
<button class="ui button"><i class="bold icon"></i></button>
<button class="ui button"><i class="underline icon"></i></button>
<button class="ui button"><i class="text width icon"></i></button>
</div>

样式如下: 

带标签的按钮分组

 <div class="ui labeled icon buttons">
<button class="ui button"><i class="pause icon"></i> 暂停 </button>
<button class="ui button"><i class="play icon"></i> 播放 </button>
<button class="ui button"><i class="shuffle icon"></i> 随机 </button>
</div>

样式如下: 

混合类型的分组

  <div class="ui buttons">
<button class="ui labeled icon button"><i class="left chevron icon"></i> 前一首 </button>
<button class="ui button"><i class="stop icon"></i> 停止 </button>
<button class="ui right labeled icon button"> 后一首 <i class="right chevron icon"></i> </button>
</div>

样式如下: 

成员等宽的分组

在分组的设置中指明包含几个成员,则这几个成员平分所能占据的宽度:

<div class="five ui buttons">
<button class="ui button">One</button>
<button class="ui button">Two</button>
<button class="ui button">Three</button>
<button class="ui button">Four</button>
<button class="ui button">Five</button>
</div>

样式如下: 

成员颜色不同的分组

<div class="ui buttons">
<button class="ui red basic button">One</button>
<button class="ui blue basic button">Two</button>
<button class="ui green basic button">Three</button>
</div>

样式如下: 

表示文件操作的按钮组

<div class="ui small basic icon buttons">
<button class="ui button"><i class="file icon"></i></button>
<button class="ui button"><i class="save icon"></i></button>
<button class="ui button"><i class="upload icon"></i></button>
<button class="ui button"><i class="download icon"></i></button>
</div>

样式如下: 

包含条件的按钮

如果是中文,需要配合Semantic UI的data-text属性为中间的or添加本地文本:

<div class="ui buttons">
<button class="ui button">Register</button>
<div class="or"></div>
<button class="ui positive button">Login</button>
</div>
<div class="ui buttons">
<button class="ui button">注册</button>
<div class="or" data-text="或"></div>
<button class="ui positive button">登录</button>
</div>

样式如下: 

不同大小的按钮

<button class="mini ui button">Mini </button>
<button class="tiny ui button">Tiny </button>
<button class="small ui button">Small </button>
<button class="medium ui button">Medium </button>
<button class="large ui button">Large </button>
<button class="big ui button">Big </button>
<button class="huge ui button">Huge </button>
<button class="massive ui button">Massive </button>

样式如下: 

紧凑的按钮

    <button class="compact ui button">普通</button>
<button class="ui compact icon button">
<i class="pause icon"></i>
</button>
<button class="ui compact labeled icon button"><i class="pause icon"></i> 暂停</button>

样式如下: 

圆形按钮

<button class="ui circular icon button">
<i class="settings icon"></i>
</button>

样式如下: 

不同位置的按钮

左右浮动的按钮

<button class="ui right floated button">右浮动</button>
<button class="ui left floated button">左浮动</button>

样式如下: 

充满整个容器的按钮

<button class="fluid ui button">Fluid</button>

样式如下: 

固定在顶部和底部的按钮

<div class="ui top attached button" tabindex="0">顶部按钮</div>
<div class="ui attached segment">
<p>这是一个段落。</p>
</div>
<div class="ui bottom attached button" tabindex="0">底部按钮</div>

样式如下: 

固定在顶部和底部的多个按钮

<div class="ui two top attached buttons">
<div class="ui button">左上角</div>
<div class="ui button">右上角</div>
</div>
<div class="ui attached segment">
<p>这是一个段落。</p>
</div>
<div class="ui two bottom attached buttons">
<div class="ui button">左下角</div>
<div class="ui button">右下角</div>
</div>

样式如下: 

固定在左右的按钮

<button class="ui left attached button"> 左</button>
<button class="ui right attached button"> 右</button>

样式如下: 

160908、前端开发框架Semantic UI的更多相关文章

  1. Semantic UI – 完全语义化的前端界面开发框架

    Semantic UI 是一个 UI 库,使前端开发更简单,更容易学习.Semantic UI 介绍了许多界面元素.在大多数情况下,只有你需要的元素建立一个自定义的构建可能是最好的. UI 组件分为四 ...

  2. 目前几款基于html5的前端框架:如Bootstrap、Foundation、Semantic UI 、Amaze UI

    Bootstrap是由Twitter在2011年8月推出的开源WEB前端框架,集合CSS 和HTML,使用了最新的浏览器技术,为快速WEB开发提供了一套前端工具包,包括布局.网格.表格.按钮.表单.导 ...

  3. Semantic UI 语义化设计的前端框架

    UI是Web的灵魂!Semantic UI是一款语义化设计的前端框架,为攻城师而制作的可复用的开源前端框架. 特性 弃用有歧义的表述 Semantic是围绕自然交流语言而架构的,这使得开发更加直观(易 ...

  4. Semantic UI 中文参考手册

    一个拥有友好词汇表的前端框架,完全语义化的前端界面开发框架,为一组开发人员之间共享UI元素配备了规格.使用的词汇(类和ID)相比其它替代品更加简洁,从而降低了学习曲线.有许多HTML元素,UI元素和场 ...

  5. 前端Js框架 UI框架汇总 特性 适用范围 选择

    身为一个资深后端工程师,面对层出不穷的前端框架,总让人眼花缭乱,做一个综合解析贴,从全局着眼,让我们明白各种前端框架的应用范围,为如何选择前端框架,从不同的维度提供一些线索,做为一个长期优化贴,欢迎指 ...

  6. Web前端开发框架大全-详述

    可以说,前端技术的发展是互联网自身发展的一个缩影! 前端技术的发展经历了web1.0时代,即网页只能展示信息,几乎没有交互可言: web2.0时代,web2.0不再是单维的,逐渐发展为双向交流,另一特 ...

  7. semantic UI first web

    官方文档:https://semantic-ui.com/introduction/getting-started.html semantic  UI: SemanticUI是一款语义化设计的前端开源 ...

  8. 2017年当下最值得你关注的前端开发框架,不知道你就OUT了!

    近几年随着 jQuery.Ext 以及 CSS3 的发展,以 Bootstrap 为代表的前端开发框架如雨后春笋般挤入视野,可谓应接不暇. 在这篇分享中,我将总结2017年当下最值得你关注的前端开发框 ...

  9. 目前比较火的前端框架及UI组件

    看到的一篇总结性的文章,收藏一下,感兴趣的可以自己看看,哪些是已经会的,哪些是没听说过的,哪些是一知半解的,都可以稍微看看. 一.前端框架库: 1.Zepto.js 地址:点击打开链接 描述:Zept ...

随机推荐

  1. 热门WEB前端职业你只需要掌握这些

    在知名的互联网企业里工作是一件很美好的事情,有很多的工作机会,而且企业们通过高薪以及令人羡慕的福利来争夺最优秀的人才.但是如果你花了大量的时间在招聘网站上和公司的帖子上,你可能会注意到在网页设计这个工 ...

  2. SQLAlchemy 对象缓存和刷新

    SQLAlchemy 对象缓存和刷新 SQLAlchemy 带有对象缓存机制,在重复查询相同的对象时,直接先查询本地的缓存,而不需要从数据库加载数据. 在每个 model 对象的内部,SQLAlche ...

  3. UIlabel多行文字自动换行 (自动折行)

    UIView *footerView = [[UIView alloc]initWithFrame:CGRectMake(, , , )]; UILabel *label = [[UILabel al ...

  4. SVG 参考手册

    1. SVG元素模块 Animation.Module animate animateColor animateTransform animateMotion set mpath 剪裁模块 clipP ...

  5. 缩进, Tab 还是空格?(转)

    圣战 圣战个毛线 Android 好还是 iOS 好,Windows 好还是 Mac 好,编辑器好还是 IDE好,中划线好还是下划线好…写代码这么多年,会遇到很多奇葩的毫无意义的所谓脑残粉的争论 昨天 ...

  6. iOS面试必看,最全梳理

    序言 目前形势,参加到iOS队伍的人是越来越多,甚至已经到供过于求了.今年,找过工作人可能会更深刻地体会到今年的就业形势不容乐观,加之,培训机构一火车地向用人单位输送iOS开发人员,打破了生态圈的动态 ...

  7. jquery实现input输入框实时输入触发事件代码

    <input id="productName" name="productName" class="wid10" type=" ...

  8. git客户端

    https://git-for-windows.github.io/ http://blog.csdn.net/shulianghan/article/details/18812279 自己的gith ...

  9. 使用jquery的小记

    随便写点 1.给span这种标签赋值  不能用$("#id").val("abc"); 因为这种标签没有value属性 而应该用$("#id" ...

  10. js - ajax中的get和post说明

    转自:http://www.cnblogs.com/hateyoucode/archive/2009/12/09/1620050.html 一.谈Ajax的Get和Post的区别 Get方式:   用 ...