好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

html5教程-CSS3 appearance大全鉴赏以及是否影响box-sizing

小宝典致力于为广大程序猿(媛)提供高品质的代码服务,请大家多多光顾小站,小宝典在此谢过。

&nbs p;

一、 CSS 3 ap PE arance 改变 元素 外观

之前写过一篇很实用也很全面的 文章 :“伪元素表单控件默认样式重置与自定义大全”,里面就大量出现了CSS3 appearance的使用,主要是重置 HTML 5表单元素浏览器内置的一些UI。例如:

去掉 date 类型 <input> 框的叉叉:

 :: - webkit -clear-button {      -webk IT -appearance: none;  }

去掉 number 类型 <input> 框的上下箭头:

::-webkit -i nner -s pin-button {      -webkit-appearance: none;     /* 上下小箭头按钮,你丫太丑了,滚粗,负分 */  }

去掉 se Arch 类型 <input> 框的N多特征:

 /* 去除 圆 角 */  input[type=search] { -webkit-appearance: none; }   /* 隐藏取消按钮 */  ::-webkit-search-cancel-button { -webkit-appearance: none; }   /* 隐藏放大镜 */  ::-webkit-search-results-button { -webkit-appearance: none; }

等等 。

兼容性
撇开IE不谈,appearance的兼容性其实已经很不错了,移动端可以愉快地使用, 不过 离不开 -webkit 或 -moz- 私有前缀。

仔细观察会发现IE13也支持,不过,根据caniuse上的提示,IE13+以及IE @R_ 126 _943@使用的是 -webkit- 而不是 -ms- !我顿时恍惚了,怎么突然出现请情敌到家里 吃 饭的剧情了?之前支付宝不支持window phone时候的口水仗听说过IE的这种做法,据说是被 开发者 逼的,今天终于逮着个活的。

其他
虽然说,实际开发时候,我们用的最多的是使用 -webkit-appearance:none 干掉浏览器默认丑陋的UI,但是,从功能上讲, appearance 还可以把普通元素变成特殊元素, 或者 A元素变成B元素的样子。

例如,一个普通的 span 标签,然后:

span { -webkit-appearance:button; -moz-appearance:button; }

就会变成按钮模样,例如下面截图(win-ch rom e, win-firefox):

实时效果如下:

button

二、CSS3 appearance其他 用途

除了改变元素的UI,CSS3 appearance还有其他用途,什么用途呢?说出来不要笑,判断 是否 是是 webkit 浏览器……本来我想这么写的!然后瞬间发现自己傻逼了,卧槽,新出的IE13,IE14也是使用的 -webkit 私有前缀,虽然身边没有设备无法测试,但是,按照以往的尿性,怕是下面的JS要悲剧了:

 VAR  isWebkit = 'WebkitAppearance' in document.documentElement.style;

这就是随便请情敌到家里吃饭的后果,看来只能先用下面这个老方法顶着:

 var isWebkit = typeof document.webkitHidden != "un define d"; 

本节就当我没说过~~

三、CSS3 appearance大全鉴赏

你 知道 webkit和moz支持的appearance属性值有多少吗?足足有一卡车那么多!

webkit浏览器下:

["checkbox", "radio", "push-button", "square-button", "button", "button-bevel", "listbox", "listitem", "menulist", "menulist-button", "menulist -t ext", "menulist-textfield", "scrollbarbutton-up", "scrollbarbutton-down", "scrollbarbutton-left", "scrollbarbutton-right", "scrollbartrack-horizontal", "scrollbartrack-vert ical ", "scrollbarthumb-horizontal", "scrollbarthumb-vertical", "scrollb arg ripper-horizontal", "scrollbargripper-vertical", "slider-horizontal", "slider-vertical", "sliderthumb-horizontal", "sliderthumb-vertical", "caret", "searchfield", "searchfield-decoration", "searchfield-results-decoration", "searchfield-results-button", "searchfield-cancel-button", "textfield", "textarea"]

moz浏览器下:

["none", "button", "checkbox", "checkbox-cont ai ner", "checkbox-small", "dia LOG ", "listbox", "menuitem", "menulist", "menulist-button", "menulist-textfield", "menupopup", " PR ogressbar", "radio", "radio-container", "radio-small", "resizer", "scrollbar", "scrollbarbutton-down", "scrollbarbutton-left", "scrollbarbutton-right", "scrollbarbutton-up", "scrollbartrack-horizontal", "scrollbartrack-vertical", "separator", " stat  usb ar", "tab", "tab-left- Edge  Obsolete", "tabpanels", "textfield", "textfield-multiline", "toolbar", "toolbarbutton", "toolbox", "-moz-mac-unified-toolbar", "-moz-win-borderless-glass", "-moz-win- br owsertabbar-toolbox", "-moz-win-communications-toolbox", "-moz-win-glass", "-moz-win-media-toolbox", "tooltip", "treeheadercell", "treeheadersortarrow", "tre ei tem", "treetwisty", "treetwistyopen", "treeview", "window"]

为了让大伙儿一下子知道各个值究竟会表现成什么样子,我特意整个了鉴赏大全页面。若有兴趣,您可以狠狠地点击这里:appearance属性webkit和moz效果大全demo

我使用了选框勾勒了元素的轮廓,这样容易分别。结果,webkit下(不同操作系统UI不一样):

四、appearance是否影响box-sizing?

这是我自己抛出的一个疑问?

比方说一个 search 类型 <input> 框,其 box-sizing 为 border-box ,而 text 类型的普通 <input> 框的 box-sizing 为 content-box 。

假如说,我通过 appearance 把 text 类型输入框变成 search 类型的模样,那么 盒模型 ,也就是 box-sizing 是不是也跟着一起变呢?

这种问题,写个demo测试下就可以了,若有兴趣,您可以狠狠地点击这里:appearance改变是否影响元素的box-sizing测试

结果,点击按钮后,元素的高度并没有变化(如下截图):

这说明, appearance 可以影响外观,但是 不影响 box-sizing , box-sizing 是由 type 属性值决定的。

五、结束语

刚想到了个点,可以分享的。后来刷了一圈 微博 ,怎么也想不起来,好痛苦,怎么办?

这比大鱼已经拖上岸结果还跑了还要难受……

难受……

难……

受……

……

觉得 可用,就经常来吧! 欢迎评论哦!  html5教程 ,巧夺天工,精雕玉琢。小宝典献丑了!

总结

以上是 为你收集整理的 html5教程-CSS3 appearance大全鉴赏以及是否影响box-sizing 全部内容,希望文章能够帮你解决 html5教程-CSS3 appearance大全鉴赏以及是否影响box-sizing 所遇到的问题。

如果觉得 网站内容还不错, 推荐好友。

查看更多关于html5教程-CSS3 appearance大全鉴赏以及是否影响box-sizing的详细内容...

  阅读:38次