一、resize实现图片对比

resize的语法如下:

resize:none | both | horizontal | vertical

案例效果如下图 (鼠标移到左下角白色区域,往右侧拖动,实现图片对比效果)

我应用到了resize的如下代码:

resize: horizontal;

可以水平拉伸!

二、:not()的应用技巧

我们平时在书写导航栏分割线的时候,最后一个标签是没有分割线的,我们一般的写法如下:

/* 先给所有添加右侧边框 */
.nav li {
border-right: 1px solid #666;
}
/* 再去除最后一个边框 */
.nav li:last-child {
border-right: none;
}

运用:not()之后如下书写:

.nav li:not(:last-child) {
border-right: 1px solid #666;
}
.nav li:first-child ~ li {
border-left: 1px solid #666;
}

我们在用逗号分隔的列表,最后一个让他没有逗号,写法如下:

ul > li:not(:last-child)::after {
content: ",";
}

not的应用,让我们方便了不少,节省了一些代码!

三、任意元素垂直居中

关于css垂直居中,代码如下:

html, body {
height: 100%;
margin: 0;
} body {
-webkit-align-items: center;
-ms-flex-align: center;
align-items: center;
display: -webkit-flex;
display: flex;
}

当然,这个有一定的兼容问题!不过现代浏览器是没有问题的!

四、表格单元格等宽

用如下代码可以让表格单元格等宽

.haorooms{
table-layout: fixed;
}

五、使用Flexbox摆脱各种Margin Hacks

实现侧栏时,我们不再需要各种nth-、first-和last-child等设置margin,可以使用Flexbox轻松实现均匀分布!代码如下:

.list {
display: flex;
justify-content: space-between;
} .list .person {
flex-basis: 23%;
}

六、给空连接使用属性选择符

我们还可以给空a标签添加属性,代码如下:

a[href^="http"]:empty::before {
content: attr(href);
}

七、初始化box-sizing

从html中继承box-sizing属性,这样的话,后期维护比较方便。

html {
box-sizing: border-box;
} *, *:before, *:after {
box-sizing: inherit;
}

八、在nth-child中使用负数

nth-child中使用负数,可以选择小于等于某个数的值,例如:

li:nth-child(-n+4){background:red}

小于等于4的li,显示为红色!

还可以如下应用:

li {
display: none;
} li:nth-child(-n+3) {
display: block;
}

上面代码的含义是,我们让前三个li显示(小于等于3的),其他的li都隐藏!

九、文本显示优化

html {
-moz-osx-font-smoothing: grayscale;
-webkit-font-smoothing: antialiased;
text-rendering: optimizeLegibility;
}

上面代码可以让字体在我们的设备中最优显示!

十、border的应用技巧!

border的应用还是蛮广泛的!我之前在慕课网的课程 html5左侧导航,讲了三道杠的书写!,是运用了box-shadow,关于文章,具体请看:http://www.haorooms.com/post/box_shadow_css

但是呢,这个是css3的属性,今天给大家讲运用border书写三道杠,兼容性很好!代码如下:

width:40px;height:7px;
color: #999;
border-top:18px double;
border-bottom: 6px solid;

运用border的double属性,可以轻松绘制三道杠,兼容性很好!并且,大家注意的是:border-color可以继承color,我们只要修改color的值,就可以修改border-color的值!

十一、vertical-align 属性

vertical-align 只在行内元素,或者inline、inline-block等中才起作用。当我们在某个div中使用垂直居中是不管用的,

除此之外,vertical-align 还支持数值和百分比!

我们可以如下写:

.haorooms{vertical-align:-2px;}
.haorooms{vertical-align:-10%;}

这个负值和 margin-bottom类似,但是呢,vertical-align可以将父级元素撑大!

十二、margin重叠解决方案列举

1、父级元素bfc ,

2、父级元素给一个padding

3、父级元素给一个border

4、子元素前面加任意一个空的内联元素,(例如:span、nbsp等等)

提高你css技能的css开发技巧(转载)的更多相关文章

  1. 提高你css技能的css开发技巧

    好久没整理博客了 进来啰嗦两句   继续抄别人的博客 一.resize实现图片对比 resize的语法如下: resize:none | both | horizontal | vertical 案例 ...

  2. 移动端web开发技巧 -- 转载

    META相关 1. 添加到主屏后的标题(IOS)<meta name="apple-mobile-web-app-title" content="标题"& ...

  3. CSS学习笔记总结和技巧

    跟叶老师说项目,他叫我写一个静态首页,看起来挺简单的,但是下手才发现在真的不会怎么下手啊,什么模型啊模块啊都不懂,写毛线啊!! 如图:页面下拉还有侧栏,中间内容等. 可是答应跟老师做了,不能怂啊,于是 ...

  4. 提高 web 应用性能之 CSS 性能调优

    简介 Web 开发中经常会遇到性能的问题,尤其是 Web 2.0 的应用.CSS 代码是控制页面显示样式与效果的最直接“工具”,但是在性能调优时他们通常被 Web 开发工程师所忽略,而事实上不规范的 ...

  5. (webstorm的CSS插件)前端开发必备!Emmet使用手册

    介绍 Emmet (前身为 Zen Coding) 是一个能大幅度提高前端开发效率的一个工具: 基本上,大多数的文本编辑器都会允许你存储和重用一些代码块,我们称之为“片段”.虽然片段能很好地推动你得生 ...

  6. [转]提高 web 应用性能之 CSS 性能调优

    简介 Web 开发中经常会遇到性能的问题,尤其是 Web 2.0 的应用.CSS 代码是控制页面显示样式与效果的最直接“工具”,但是在性能调优时他们通常被 Web 开发工程师所忽略,而事实上不规范的 ...

  7. 前端开发人员要注意的css规范,css命名。

    刚工作的时候也没注意关于css的规则,根据自己的心情想怎么用就怎么用,完成工作就好不会考虑代码的可读性,加载的性能,现在身为前端的一员就要有程序员的自我修养(嘿嘿,是不是很有责任感啊). 废话不多说, ...

  8. CSS兼容性(IE和Firefox)技巧大全

    CSS对浏览器的兼容性有时让人很头疼,或许当你了解当中的技巧跟原理,就会觉得也不是难事,从网上收集了IE7,6与Fireofx的兼容性处理技巧并整理了一下.对于web2.0的过度,请尽量用xhtml格 ...

  9. css选择器顺序的小技巧

    在线演示 本地下载 css的选择器的顺序其实很有意思,如果应用的好的话,可以做一些简单的逻辑出来,配合上css3,就可以尽可能的脱离js了. 这里的演示是一个带有hover事件的四张照片,效果来自一个 ...

随机推荐

  1. c++ 使用shell命令

    #include <iostream> #include <stdio.h> #include <vector> #include <unistd.h> ...

  2. Oauth2.0

    注:Access token 为第三方平台的token,在用户授权时使用Refresh Token为用户的token get/post参数时,一般采用字典排序

  3. VC++6.0 配置CppUTest测试环境

    最近看<软件项目成功之道>,书中无数次提及到“单元测试”对于项目成败的重要性,看到同事将CppUTest用于Linux动态库测试,于是在VC++6.0环境下搭建一个基于CppUTest的单 ...

  4. Python-7 列表list

    #1 创建列表.向列表中添加元素 1) 列表名称.append(*) 2) 列表名称.extend([*,*,...]) 3) 列表名称.insert(位置,*) member = ['小甲鱼','小 ...

  5. SQL Server 2008通过LinkServer连接MySQL

    链接过程就不过多描述了,搜索下都有一大堆的内容. 链接成功以后,如何调用的问题,通过“编写select脚本”的方式生成的脚本如下: [备注:asset_manager是数据库名,admin是表名] - ...

  6. Windows WMIC命令使用详解

    本文转载出处http://www.jb51.net/article/49987.htm www.makaidong.com/博客园文/32743.shtml wmic alias list brief ...

  7. iOS静态分析举例

    XCode-> Product -> Analyze 即可进行iOS静态代码分析.静态分析能发现的问题包括以下几种类型: 1.逻辑错误:访问空指针或未初始化的变量等: 2.内存管理错误:如 ...

  8. 移动端网页fixed布局问题解决方案

    问题说明 移动端web的footer常常设计为fixed布局,但是在页面键盘被拉起时fixed的布局会出现问题,自己试了下,在较低版本ios和部分安卓机上会有此问题.具体问题看图示: <body ...

  9. 关于tomcat小知识

    1.linux下的tomcat中有用于记录日志的catalina.out文件(在logs下),windows中没有.catalina.out文件主要记录system.out  system.err等  ...

  10. HTTP 错误500.19 -Internal Server Error 错误代码 0x80070021

    转自:http://blog.csdn.net/goux_s/article/details/5676689 错误摘要 HTTP 错误500.19 -Internal Server Error 无法访 ...