移动开发基础-学习笔记二-字体图标、less、bootstrap入门
1.字体图标
1.字体图标都是用svg图片
1.svg图片不失真
2.svg图标由设计师提供
3.为了减少网络请求,会把svg图标转换成字体图标,放到字体文件中,通过字体库的方式使用
2.制作步骤
1.上传字体图标到在线制作网站:阿里图标库或iconmoon
2.下载代码
3.注意点:在上传之前要把图标的名字改好,不然类名会带有后缀
3.原理
1.css3语法引入字体:@font-face
@font-face {
font-family: "自定义字体名";
src : url() format(),
url() format()
}
1.自定义字体名:后面需要使用该字体名
2.引入多个url:兼容各种浏览器
3.format:声明资源格式,方便浏览器识别
2.将字体用类包装在类名中 ,方便赋予样式
1..icon { font-family: "自定义字体名" }
2.高级方法: [class^="icon-"],[class*=" icon-"]{ font-family: "自定义字体名" }
3.将图标编码包装在类名中,方便赋予样式
.icon-名字 { content: "unicode转码" }
2.html转码在下载的文件中就有
2.预处理器
1.作用:让css变得更加简洁和强大
2.原理:预先写好一些高级的css,通过特定编译方式再转成css让浏览器识别
3.常见的预处理器
1.less:目前最流行
1.引入less
1.引入less文件:<link type="stylesheet/less" src>
2.引入less编译文件:less.js
用于编译less文件,应该就是获取上面的less文件,然后通过正则表达式将less文件转换成css代码,放在head里面,作为内嵌式。所以需要放在less文件后面
2.sass
3.stylus
4.相似,只要学会一种,其他的就都会了
3.less
1.特点
1.完全兼容css,并且扩展了css
2.语法简洁,与css类似,容易上手
3.使用less.js编译
2.语法
1.变量
2.mixins混入(自定义函数)
3.嵌套(跟标签一样嵌套,外面容器不需要重复写)
4.操作(运算符+-*/)
5.转码(把一些css代码当成字符串转码到里面)
6.函数(系统函数)
3.具体使用
1.编译
1.使用node.js编译(暂时不学)
2.引入文件进行编译
1.引入cdn托管的静态资源
2.引入自己的less.js
3.需要使用服务器打开
3.vscode有编译插件
4.开发中,使用less.js;上线用编译完之后css文件
用less.js会在html页面上报错
2.变量
1.定义变量
1.@变量名:变量值
2.命名规范和js差不多,只用一个差别:中间可以有横杠
2.使用变量:@变量名
3.嵌套
1.嵌套的选择器是css中的选择器,一般情况下,嵌套中的一级括号相当于css中的空格
2.嵌套中的&表示上一层的选择器,与js中this作用相同。一般用在伪类,伪元素,交集选择器中
4.运算符
5.引入其他less文件:@import 路径
在哪里写这句代码,目标文件的内容就引入到那里。
一般在最前面引入
6.使用细节
1.在一个选择器a中写另一个选择器b,可以将选择器b中的代码带入这个位置
2.通常把变量和自定义函数分别封装在特定的文件中
1.变量:variables.less
2.函数:mixins.less
3.
7.less.js工作原理
1.通过rel请求less文件
需要服务器
2.通过js中的正则表达式将less转换成css文件
3.将css代码动态添加到style标签中
8.编译
1.开发环境中使用less.js,因为这样在less中有错误时,html页面胡报错
2.在生产环境中使用已编译好的css文件
4.选择器
1.下一个兄弟选择器:+。选中下一个符合条件的兄弟元素
.box1 + .box2 选中.box1下一个且类名为.box2元素
2.后面兄弟选择器:~。选中后面所有符合条件的兄弟元素
.box1 ~ .box2:选中.box1后面所有类名为.box2的兄弟元素
3.一般用于排除第一个兄弟元素
1.补充知识
1.以后开发中大部分都是用border-box
2.栅格系统中的所有元素都加了相对定位
3.不推荐给父元素加高度,用子元素撑开
4.bootstrap里面如果在动画时样式消失,则可能是类名被覆盖,或标签、样式名被动画修改
5.轮播图的图片
1.大中小屏幕使用大图片,且宽高不应该随屏幕宽度的变化而变化,因为这样会让图片难以看清。这时候的图片应该作为背景,背景居中,然后轮播图高给定,宽度自适应。
2.宽度自适应,超小屏幕使用小图片,并且宽高自使用就行了,因为小屏幕的宽高变化不大
6.对一整个句子如果会换行,则应该使用padding让文字居中。如果一整个句子不会换行,就使用行高居中
XMind: ZEN - Trial Version
移动开发基础-学习笔记二-字体图标、less、bootstrap入门的更多相关文章
- ASP.Net MVC开发基础学习笔记:一、走向MVC模式
一.ASP.Net的两种开发模式 1.1 ASP.Net WebForm的开发模式 (1)处理流程 在传统的WebForm模式下,我们请求一个例如http://www.aspnetmvc.com/bl ...
- ASP.Net MVC开发基础学习笔记(1):走向MVC模式
一.ASP.Net的两种开发模式 1.1 ASP.Net WebForm的开发模式 (1)处理流程 在传统的WebForm模式下,我们请求一个例如http://www.aspnetmvc.com/bl ...
- ASP.Net MVC开发基础学习笔记:二、HtmlHelper与扩展方法
一.一个功能强大的页面开发辅助类—HtmlHelper初步了解 1.1 有失必有得 在ASP.Net MVC中微软并没有提供类似服务器端控件那种开发方式,毕竟微软的MVC就是传统的请求处理响应的回归. ...
- Java基础学习笔记二十八 管家婆综合项目
本项目为JAVA基础综合项目,主要包括: 熟练View层.Service层.Dao层之间的方法相互调用操作.熟练dbutils操作数据库表完成增删改查. 项目功能分析 查询账务 多条件组合查询账务 添 ...
- Java基础学习笔记二十六 JDBC
什么是JDBC JDBC(Java DataBase Connectivity)就是Java数据库连接,说白了就是用Java语言来操作数据库.原来我们操作数据库是在控制台使用SQL语句来操作数据库,J ...
- ASP.Net MVC开发基础学习笔记:三、Razor视图引擎、控制器与路由机制学习
一.天降神器“剃须刀” — Razor视图引擎 1.1 千呼万唤始出来的MVC3.0 在MVC3.0版本的时候,微软终于引入了第二种模板引擎:Razor.在这之前,我们一直在使用WebForm时代沿留 ...
- ASP.Net MVC开发基础学习笔记:四、校验、AJAX与过滤器
一.校验 — 表单不是你想提想提就能提 1.1 DataAnnotations(数据注解) 位于 System.ComponentModel.DataAnnotations 命名空间中的特性指定对数据 ...
- ASP.Net MVC开发基础学习笔记:五、区域、模板页与WebAPI初步
一.区域—麻雀虽小,五脏俱全的迷你MVC项目 1.1 Area的兴起 为了方便大规模网站中的管理大量文件,在ASP.NET MVC 2.0版本中引入了一个新概念—区域(Area). 在项目上右击创建新 ...
- ASP.Net MVC开发基础学习笔记(5):区域、模板页与WebAPI初步
一.区域—麻雀虽小,五脏俱全的迷你MVC项目 1.1 Area的兴起 为了方便大规模网站中的管理大量文件,在ASP.NET MVC 2.0版本中引入了一个新概念—区域(Area). 在项目上右击创建新 ...
随机推荐
- Java 运算符 % 和 /
/ 是除运算符, %是取模运算符 区别: / 是普通的除法运算,如果除数和被除数都是整数,则商是取整 %是求余数 private static void test() { System. / ); S ...
- Scrapy爬取Ajax(异步加载)网页实例——简书付费连载
这两天学习了Scrapy爬虫框架的基本使用,练习的例子爬取的都是传统的直接加载完网页的内容,就想试试爬取用Ajax技术加载的网页. 这里以简书里的优选连载网页为例分享一下我的爬取过程. 网址为: ht ...
- CSharpGL(46)用Billboard绘制头顶文字
CSharpGL(46)用Billboard绘制头顶文字 本文介绍CSharpGL用Billboard绘制头顶文字的方法.效果如下图所示. 下载 CSharpGL已在GitHub开源,欢迎对OpenG ...
- asp.net core 系列之并发冲突
本文介绍如何处理多个用户并发更新同一实体(同时)时出现的冲突 . 主要是两种:一种,检查属性并发冲突,使用 [ConcurrencyCheck] ;另一种,检测行的并发冲突,使用 rowversion ...
- r.js合并实践
项目中用到require.js做生产时模块开发,但上线要合并压缩,幸好它配套有r.js.下面就其用法说明一下. 首先建一个目录,里面的结构如下: require.js可以到r.js项目下载 r.js可 ...
- AI - TensorFlow - 张量(Tensor)
张量(Tensor) 在Tensorflow中,变量统一称作张量(Tensor). 张量(Tensor)是任意维度的数组. 0阶张量:纯量或标量 (scalar), 也就是一个数值,例如,\'Howd ...
- Docker & ASP.NET Core (4):容器间的连接
第一篇:把代码连接到容器 第二篇:定制Docker镜像 第三篇:发布镜像 Docker容器间的连接 Docker提供了两种方式可以用来做容器间的连接/通信: Legacy Linking:这种方式使用 ...
- WebPack引用Bootstrap 无法使用图标的结局方案
npm i https://github.com/iconic/open-iconic.git -D 因为boostrap的css里删除了图标 分开了 我们在引入个呵呵. 下载:npm i boot ...
- freeSSHD在windows环境下搭建SFTP服务器
freeSSHD在windows环境下搭建SFTP服务器 0 建议现在windows环境下安装cygwin,否则在windows环境下cmd模式使用不了sftp去连接,可以利用win scp去测试连接 ...
- [区块链] 带你进入Bitcoin开发 - 环境搭建
学习完区块链枯燥乏味的.高深的.必备的基础知识后,终于可以走上开发之路了!真是迫不及待啦!之后博客更新主要放在区块链的开发上,相信这才是大多数同学更加感兴趣的地方!学习过程从最经典的区块链鼻祖-比特币 ...