如何使用CSS3中appearance属性改变元素的外观

这篇文章主要介绍了关于如何使用css3appearance属性改变元素的外观,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下

大家都知道每个浏览器对HTML元素渲染都不一样,比如说button,在chrome和ff中,渲染出来的效果都是不尽相同的。这样一来就有了今天这个思路,利用浏览器的对元素的默认渲染风格,我们可以使用appearance属性对任何元素的渲染风格改变

前段时间在《修复iPhone上submit按钮bug》中介绍了使用“-webkit-appearance: none; ”来改变按钮在iPhone下的默认风格,其实我们可以反过来思路,使用“appearance”属性,来改变任何元素的浏览器默认风格,简单的说,你可以使用“appearance”属性将“段落p”渲染成button的风格,也可以渲染成“输入框”、“选择框”等效果。
大家都知道每个浏览器对HTML元素渲染都不一样,比如说“button”,在chrome和ff中,渲染出来的效果都是不尽相同的。这样一来就有了今天这个思路,利用浏览器的对元素的默认渲染风格,我们可以使用“appearance”属性对任何元素的渲染风格改变,最简单的来说,我要把“a”链接默认显示成“按钮”风格,那么我们可以使用“appearance”设置为“button”。
“appearance”功能听起来蛮大的,不过可惜的是,目前各个浏览器厂商各自为政,还无法达到统一的标准,至今天也只有两个内核的浏览器可以使用,其一是“webkit”,其二是“ff”的,也就是说在使用“appearances”时,需要加上各浏览器厂前缀。
appearance使用方法:

.elmClass{      -webkit-appearance: value;      -moz-appearance:    value;      appearance:         value;   }

接下来我们一起来看个简单的实例:

我是一个段落P元素

我是一个段落P元素

我是一个段落P元素

我是一个段落P元素

我是一个段落P元素

我是一个段落P元素

接下来,使用“appearance”属性来改变上面“P”元素的风格:

立即学习“前端免费学习笔记(深入)”;

/*看起来像个按钮,以按钮的风格渲染*/   .lookLikeAButton{        -webkit-appearance:button;        -moz-appearance:button;   }   /*看起来像个清单盒子,以listbox风格渲染*/   .lookLikeAListbox{        -webkit-appearance:listbox;        -moz-appearance:listbox;   }   /*看起来像个清单列表,以listitem风格渲染*/   .lookLikeAListitem{        -webkit-appearance:listitem;        -moz-appearance:listitem;   }   /*看起来像个搜索框,以searchfield风格渲染*/   .lookLikeASearchfield{        -webkit-appearance:searchfield;        -moz-appearance:searchfield;   }   /*看起来像个文本域,以textarea风格渲染*/   .lookLikeATextarea{        -webkit-appearance:textarea;        -moz-appearance:textarea;   }   /*看起来像个下接菜单,以menulist风格渲染*/   .lookLikeAMenulist{        -webkit-appearance:menulist;        -moz-appearance:menulist;   }

经过“appearance”的属性值设置后,段落P的默认风格就被改变了,如图所示:
如何使用CSS3中appearance属性改变元素的外观

当然上面的属性只是“appearance”中的一部分,我搜集了一下webkit和Mozilla下的appearance给大家参考:

Webkit下的appearance属性值

checkboxradiopush-buttonsquare-buttonbuttonbutton-bevellistboxlistitemmenulistmenulist-buttonmenulist-textmenulist-textfieldscrollbarbutton-upscrollbarbutton-downscrollbarbutton-leftscrollbarbutton-rightscrollbartrack-horizontalscrollbartrack-verticalscrollbarthumb-horizontalscrollbarthumb-verticalscrollbargripper-horizontalscrollbargripper-verticalslider-horizontalslider-verticalsliderthumb-horizontalsliderthumb-verticalcaretsearchfieldsearchfield-decorationsearchfield-results-decorationsearchfield-results-buttonsearchfield-cancel-buttontextfieldtextarea

Mozilla下的appearance属性值

nonebuttoncheckboxcheckbox-containercheckbox-smalldialoglistboxmenuitemmenulistmenulist-buttonmenulist-textfieldmenupopupprogressbarradioradio-containerradio-smallresizerscrollbarscrollbarbutton-downscrollbarbutton-leftscrollbarbutton-rightscrollbarbutton-upscrollbartrack-horizontalscrollbartrack-verticalseparatorstatusbartabtab-left-edge Obsoletetabpanelstextfieldtextfield-multilinetoolbartoolbarbuttontoolbox-moz-mac-unified-toolbar-moz-win-borderless-glass-moz-win-browsertabbar-toolbox-moz-win-communications-toolbox-moz-win-glass-moz-win-media-toolboxtooltiptreeheadercelltreeheadersortarrowtreeitemtreetwistytreetwistyopentreeviewwindow

大家要是感兴趣的话可以看看下面的相关介绍:

Mozilla Docs for -moz-appearance

Trent Walton on Webkit Appearance

Shaun Inman on Disabling Inner Text Shadow of Text Inputs on iPad

CSS3 Spec

CSS property: -webkit-appearance

最后在提醒大家一回,目前在IE系列和Opera浏览器上不支持“appearance”,而且Safari也只有3.0版本以上支持,而在Chrome和Firefox以及移动设置浏览器上得到较好的支持。如果大家对此感兴趣,自己可以私下一个下个尝试上面的属性值,给大家带来何种效果。

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

关于CSS3中常见transformation图形变化的用法

关于CSS3的animation实现逐帧动画效果

以上就是如何使用CSS3中appearance属性改变元素的外观的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1610393.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 01:25:28
下一篇 2025年12月24日 01:25:32

相关推荐

  • 关于CSS3的@font face规则的解析

    这篇文章主要介绍了真正了解css3背景下的@font face规则,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 很多人只要一提到 @font face 规则,心中就会不由自主“哦~~”的一声:“这个我知道,可以用来生成自定义字符小图标!”话是没错,问题在于很多人就以为生成字符小图标就是 @fo…

    2025年12月24日 好文分享
    000
  • 如何使用CSS3制作彩色进度条样式

    这篇文章主要介绍了关于如何使用css3制作彩色进度条样式,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 用CSS3的border-radius、box-shadow、transition、-moz-linear-gradient、-webkit-gradient等样式就可以完成一个时…

    2025年12月24日
    000
  • CSS3的animation实现简易幻灯片轮播特效

    这篇文章主要为大家详细介绍了css3 animation实现简易幻灯片轮播特效,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 CSS3有个别特性,可以触发硬件GPU来加速渲染,而不是调用默认浏览器引擎渲染; 但是很多属性,默认都是不开启硬件加速的;需要触发条件,一个最简单的触发条件就是使用3D属…

    2025年12月24日
    000
  • 如何使用CSS3实现千变万化的文字阴影text-shadow的效果

    这篇文章主要介绍了css3实现千变万化的文字阴影text-shadow效果设计的相关资料,感兴趣的小伙伴们可以参考一下 本文实例为大家分享了CSS3千变万化的文本阴影text-shadow效果实例,供大家参考,具体内容如下 语法: none||none|[,]*或none||[,]* 取值简单说明:…

    2025年12月24日 好文分享
    000
  • 关于CSS3使用transition属性实现过渡效果

    css3中新增的transform属性,可以实现元素在变换过程中的过渡效果,实现了基本的动画。下面通过本文给大家介绍css3使用transition属性实现过渡效果,需要的朋友参考下本文 属性详解 transition属性目的是让css的一些属性(如background)的以平滑过渡的效果出现。它是…

    好文分享 2025年12月24日
    000
  • 如何使用CSS3配合IE滤镜实现渐变和投影的效果

    这篇文章主要介绍了使用css3配合ie滤镜实现渐变和投影的效果的一些方法,尽管ie即将退出历史舞台,但也可以为edge浏览器的相关开发积累经验,需要的朋友可以参考下 线性渐变在CSS3和IE滤镜中的实现对于完美主义者来说,为了一个渐变而使用一张图片是一件痛苦的事情,就像有鼻屎不抠掉一样痛苦= =。所…

    2025年12月24日 好文分享
    000
  • 利用html和CSS3实现导航栏

    本篇文章给大家分享基于html和css3制作酷炫的导航栏,效果非常美观,需要的朋友可以从参考下  主要亮点:   1 ul 水平显示   2 li 去掉圆点   3 li中字体水平、竖直居中 立即学习“前端免费学习笔记(深入)”;   4 li控制边框样式   5 使用html + css3 渐变画…

    2025年12月24日
    000
  • 使用CSS3实现模拟IOS滑动开关效果

    这篇文章主要为大家详细介绍了css3模拟ios滑动开关效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 前言 H5站点需要IOS滑动按钮的效果,想了想似乎CSS3能搞起,就折腾出来了…挺简单的..请看注释 效果 代码 立即学习“前端免费学习笔记(深入)”; CSS3模拟IOS开关 …

    2025年12月24日
    000
  • 关于CSS3实现自定义Checkbox的特效

    这篇文章主要给大家介绍了利用css3实现自定义checkbox特效的相关资料,文中给出了完整的实例代码供大家参考学习,相信对大家学习自定义checkbox样式具有一定的参考价值,感兴趣的朋友们下面来一起看看吧。 前言 大家都知道CheckBox是在HTML中让使用者与首页上的素材发生交互作用的一种方…

    2025年12月24日
    000
  • 关于使用CSS3制作动画的方法

    这篇文章主要介绍了css3动画制作的简单示例,特别是像文中这样实现一个动态表情的情况是非常给力的~需要的朋友可以参考下 CSS3 大大强化了制作动画的能力,但是如果要做出图案比较复杂的动画,选择 GIF 依然是一个不错的选择。今天给大家介绍一个使用 CSS animation 配合雪碧图(CSS s…

    2025年12月24日
    000
  • 如何使用CSS3的box-reflect来制作倒影效果

    以前要实现这种效果,我们只能乖乖的找设计去制作,然后在页面上插入一张图片,但是随着css3的出现,我们可以纯代码实现,如何实现呢?就是通过css3的box-reflect属性。下面这篇文章就给大家分享了用css3来制作倒影效果的方法,有需要的朋友们可以参考借鉴。 兼容性 既然是CSS3的属性,我们当…

    2025年12月24日 好文分享
    000
  • 关于CSS3中border-image属性的使用

    这篇文章主要介绍了详解css3中border-image的使用,是css3入门学习中的基础知识,需要的朋友可以参考下 最近在项目中用到了border-image,一直是只知其名,不知其用。 最终效果是这样的:且随着border宽度变化。下图灰色部分带斜纹的是border 先看下css: border…

    2025年12月24日
    000
  • 如何利用CSS3制作简单的3d半透明立方体图片

    这篇文章主要给大家介绍了利用css3制作简单的3d半透明立方体图片展示的相关资料,文中给出了完整的示例代码,对大家的理解和学习具有一定的参考价值,需要的朋友们下面来一起看看吧。 效果图如下: 示例代码: new document //css部分html{font-size:62.5%;}img{wi…

    2025年12月24日
    000
  • 利用CSS3绘制打火机动画火焰的效果

    这篇文章主要为大家详细介绍了纯css3绘制打火机动画火焰效果的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 本文实例为大家分享了纯CSS3绘制打火机动画火焰效果的具体代码,供大家参考,具体内容如下 主要涉及到了以下属性: animation(webkit-animation), @ke…

    2025年12月24日
    000
  • 关于css3中矩阵的使用方法

    这篇文章主要介绍了css3 矩阵的使用详解的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 css3 矩阵变化. 应用格式为: transform: matrix(a,b,c,d,e,f);对应于就是: 实际应用中的转换就是: 立即学习“前端免费学习笔记(深入)…

    2025年12月24日
    000
  • 使用CSS3实现超酷的黑猫警长首页

    这篇文章主要为大家介绍了css3实现超酷的黑猫警长首页的相关代码,效果酷炫,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 先看看效果图: 具体代码: text-shadowbody {/*清除页边距,设计主色调*/ padding: 0px; margin: 0px; color: #666; …

    2025年12月24日 好文分享
    000
  • 关于开发CSS3弹性盒模型的方法之一

    这篇文章主要为大家分享了css3弹性盒模型开发笔记,对兼容性,不同属性进行介绍,感兴趣的小伙伴们可以参考一下 弹性盒模型(Flexible Box Moudle),该模型用于决定元素在盒子中的分布方式以及处理盒子的可用空间。这与XUL(Firefox浏览器的用户交互语言)相似,其他语言也使用相同的盒…

    2025年12月24日
    000
  • 关于开发CSS3弹性盒模型的方法之二

    这篇文章主要为大家分享了css3弹性盒模型开发笔记,想要学好css3弹性盒模型的朋友不要错过这篇文章,可以参考一下 本文为大家继续分享CSS3弹性盒模型开发笔记第二篇,之前一篇以及为大家引入了CSS3弹性盒模型的相关介绍,点击查看:CSS3弹性盒模型开发笔记(一) box-flex属性 box-fl…

    2025年12月24日 好文分享
    000
  • 如何使用CSS3实现折角效果

    这篇文章主要为大家介绍了利用css3实现折角的效果,当鼠标移动到图片上的时候就会出现折角的效果,文中给出了实例代码更方便大家的理解和学习,下面大家来一起学习学习吧。 先来看看静态的效果图 实例代码 body { background-color: #eaf0f2; } h1{text-align: …

    2025年12月24日
    000
  • 如何利用CSS3伪元素实现逐渐发光的方格边框

    这篇文章主要给大家介绍了利用css3伪元素实现逐渐发光的方格边框的相关资料,文中给出了详细的示例代码供大家参考学习,对大家具有一定的参考学习价值,需要的朋友们下面来一起看看吧。 本文介绍的是一个使用伪元素来实现边框逐渐发光的代码,主要用到scale和opacity这两个属性。下面来看看详细的介绍: …

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信