`
tomcat_oracle
  • 浏览: 318034 次
社区版块
存档分类
最新评论

5种你未必知道的JavaScript和CSS交互的方法

阅读更多

用JavaScript获取伪元素(pseudo-element)属性

大家都知道如何通过一个元素的style属性获取它的CSS样式值,但能获取伪元素(pseudo-element)的属性值吗?可以的,使用JavaScript也可以访问页面中的伪元素。

1 // Get the color value of .element:before
2 var color = window.getComputedStyle(
3     document.querySelector('.element'), ':before'
4 ).getPropertyValue('color');
5  
6 // Get the content value of .element:before
7 var content = window.getComputedStyle(
8     document.querySelector('.element'), ':before'
9 ).getPropertyValue('content');

看见了吗,我能访问伪元素里的content属性值。如果你想创建一个动态的,风格别致的网站,这是一种非常有用的技术!

classList API

很多的JavaScript工具库里都有addClassremoveClasstoggleClass等方法。为了对老式浏览器的兼容,这些类库采用的方法都是先搜索元素的className,追加和删除这个类,然后更新className。其实有一个新型的API提供了添加,删除和反转CSS类属性的方法,叫做classList:

1 myDiv.classList.add('myCssClass'); // Adds a class
2  
3 myDiv.classList.remove('myCssClass'); // Removes a class
4  
5 myDiv.classList.toggle('myCssClass'); // Toggles a class

大多数的浏览器里很早就实现了classListAPI,而且最终IE10里也实现了它。

直接对样式表进行添加和删除样式规则

我们都非常熟悉使用element.style.propertyName来修改样式,使用JavaScript能帮助我们做到这些,但你知道如何新增或修一个现有的CSS样式规则吗?其实非常的简单。

01 function addCSSRule(sheet, selector, rules, index) {
02     if(sheet.insertRule) {
03         sheet.insertRule(selector + "{" + rules + "}", index);
04     }
05     else {
06         sheet.addRule(selector, rules, index);
07     }
08 }
09  
10 // Use it!
11 addCSSRule(document.styleSheets[0], "header""float: left");

这种方法通常是用来创建一个新的样式规则,但如果你想修改一个现有的规则,也可以这样做。

加载CSS文件

延迟加载图片、JSON、脚本等是用来加快页面显示速度的好方法。我们可以使用curl.js等这样JavaScript加载器来延迟加载这些外部资源,可你知道CSS样式表也可以延迟加载吗,而且在加载成功后回调函数会给予通知。

01 curl(
02     [
03         "namespace/MyWidget",
04         "css!namespace/resources/MyWidget.css"
05     ], 
06     function(MyWidget) {
07         // 你可以对MyWidget进行操作
08         // 这里没有对这个CSS文件引用,因为不需要;
09         // 我们只需要它已经加载到页面上了
10     }
11 });

本网站使用的PrismJS语法高亮脚本就是延迟加载的。当所有的资源都加载后,回调函数就会触发,我可在回调函数里加载它。非常有用!

CSS鼠标指针事件

CSS鼠标指针事件pointer-events属性非常的有趣,它的功效非常像JavaScript,当你把这个属性设置为none时,它能有效的阻止禁止这个元素,你也许会说“这又如何?”,但事实上,它是禁止了这个元素上的任何JavaScript事件或回调函数!

1 .disabled { pointer-events: none; }

点击这个元素,你会发现任何你放置在这个元素上的{敏感词}都不会触发任何事件。一个神奇的功能,真的——你不在需要为了防止某个事件会被触发而去检查某个css类是否存在。

就是这5给你也许还没有发现的CSS和JavaScript交互的方法。你还有新的发现吗?分享出来!

3
0
分享到:
评论

相关推荐

    你未必知道的JavaScript和CSS交互的5种方法

    下面要讲的这五种JavaScript和CSS共同合作的方法你也许未必知道! 用JavaScript获取伪元素(pseudo-element)属性 大家都知道如何通过一个元素的style属性获取它的CSS样式值,但能获取伪元素(pseudo-element)的属性值...

    5种 CSS 和 JS 的交互方式

    标题中的“5种CSS和JS的交互方式”指的是在网页开发中,JavaScript与CSS之间进行交互的五种方法。这些方法让开发者能够更好地控制页面的动态表现和交互性。描述中提到的“使用JavaScript获取CSS伪元素属性”和“使用...

    JavaScript+jQuery交互式Web前端开发-源代码.zip

    JavaScript 和 jQuery 提供了与这两者交互的方法,可以动态改变 HTML 元素的属性和 CSS 样式,实现动态效果。 本教程的源代码中,可能包含了以下知识点: 1. DOM(文档对象模型)操作:使用 JavaScript 或 jQuery ...

    动态网页设计与制作(HTML5+CSS3+JavaScript)源代码和素材.zip

    HTML5、CSS3和JavaScript是构建现代网页的三大核心技术,它们共同作用于动态网页的设计与制作,赋予网页交互性、视觉吸引力和功能多样性。在这个"动态网页设计与制作(HTML5+CSS3+JavaScript)源代码和素材.zip"压缩包...

    疯狂HTML 5CSS 3JavaScript讲义光盘代码

    在"疯狂HTML 5CSS 3JavaScript讲义光盘代码"中,可能包含了一系列教程章节,涵盖了这些技术的基础到进阶内容,比如: 1. HTML5的新元素和API:讲解如何使用新的语义元素,以及如何利用Canvas、Web Storage、Web ...

    HTML、CSS 和 JavaScript动态、交互式的网页 .txt

    HTML、CSS 和 JavaScript动态、交互式的网页HTML、CSS 和 JavaScript动态、交互式的网页HTML、CSS 和 JavaScript动态、交互式的网页HTML、CSS 和 JavaScript动态、交互式的网页HTML、CSS 和 JavaScript动态、交互式...

    HTML5+CSS3+JavaScript网页设计案例课堂-课本源代码.zip

    HTML5、CSS3和JavaScript是构建现代网页的三大核心技术,它们共同构成了网页的结构、样式和交互性。这个"HTML5+CSS3+JavaScript网页设计案例课堂-课本源代码.zip"压缩包很可能是用于教学或自学目的的资源,包含了一...

    jQuery.JavaScript与CSS开发入门经典

    《jQuery.JavaScript与CSS开发入门经典》是一本旨在引导初学者进入前端开发领域的书籍,它涵盖了Web开发中三个至关重要的技术:jQuery、JavaScript和CSS。这三者是构建交互式和动态网页的基础,也是现代Web开发的...

    HTML5+CSS3+Javascript离线版参考手册

    JavaScript是一种广泛使用的解释型、基于原型的脚本语言,它是实现网页交互性和动态效果的关键。JavaScript.chm手册可能涵盖了变量、数据类型、控制流、函数、对象、数组、正则表达式、DOM操作、BOM处理、事件处理、...

    疯狂HTML5_CSS3_JavaScript讲义_原书光盘

    李刚以其程序员的独特视角,深入浅出地介绍了HTML5、CSS3和JavaScript这三种核心的前端技术,旨在帮助读者从软件开发的角度理解和应用这些技术。 HTML5是现代网页开发的基础,它对HTML4进行了大量的改进和扩展。书...

    HTML5+CSS3+JavaScript网页制作从入门到精通054245【实例示例源程序】

    HTML5、CSS3和JavaScript是构建现代网页的三大核心技术,它们共同构成了网页的结构、样式和行为。这个压缩包文件“HTML5+CSS3+JavaScript网页制作从入门到精通054245【实例示例源程序】”显然包含了丰富的学习资源,...

    JavaScript&jQuery;交互式Web前端开发

    交互式Web前端开发》欢迎选择一种更高效的学习JavaScript和jQuery的方式。你是一名JavaScript新手?或是您曾经向自己的Web页面上添加过一些脚本,但想以一种更好的方式来实现它们?本书非常适合您。《JavaScript&...

    基于HTML5+css3+JavaScript+java+mysql 实现的管理系统.zip

    在这个项目中,HTML5作为前端展示的基础,CSS3负责样式设计和交互效果,JavaScript用于增强用户体验,而Java作为后端语言处理业务逻辑,MySQL作为数据库存储系统数据。 【HTML5】HTML5是超文本标记语言的最新版本,...

    HTML5+CSS3+JavaScript 网页设计与制作期末综合大作业 G20五个页面(附完整答案和学生用要求及素材)

    HTML5、CSS3和JavaScript是现代网页设计与开发的核心技术,它们共同构建了网页的结构、样式和交互性。在“HTML5+CSS3+JavaScript 网页设计与制作期末综合大作业”中,学生们将面临一个挑战,即创建一个以G20为主题、...

    php css mysqL javascript html css开发手册

    JavaScript5版本引入了新的ECMAScript 5规范,包括严格模式、对象字面量、数组和对象的新增方法等。 php5.chm: PHP(Hypertext Preprocessor)是一种广泛使用的服务器端脚本语言,尤其适合Web开发。手册可能包含...

    基于CSS的Java和JavaScript交互式图书馆设计源码

    该项目为交互式图书馆设计源码,采用CSS作为主要设计语言,并融合Java和JavaScript实现动态交互功能。项目包含193个文件,其中56个为CSS样式文件,32个为Java源代码文件,27个为JAR包文件,17个为JSP页面文件,15个...

    HTML+CSS+JavaScript网页模板

    HTML(HyperText Markup Language)是用于创建网页内容的标记语言,CSS(Cascading Style Sheets)则负责定义这些内容的视觉样式,而JavaScript是一种强大的脚本语言,用于增加网页的动态功能和交互性。 在HTML5中...

    HTML5_CSS3_JavaScript中文参考手册【超全版】

    **JavaScript** 是一种轻量级的解释型编程语言,主要用于网页和用户的交互。在ES6(ECMAScript 6)及其后续版本中,JavaScript引入了类(Classes)、箭头函数(Arrow Functions)、模板字符串(Template Literals)...

    基于CSS3和HTML5,Javascript的静态网页

    在现代Web开发中,CSS3、HTML5以及JavaScript是构建动态和交互式静态网页的核心技术。这三种技术的结合使得开发者能够创建出丰富、响应式的用户体验,为用户提供更直观、更具吸引力的网络浏览环境。 首先,HTML5是...

    基于Python、HTML、JavaScript和CSS的交互式数据可视化设计源码

    本项目是一个基于Python、HTML、JavaScript和CSS的交互式数据可视化设计源码,总计包含4753个文件,涵盖了2240个Python编译文件、2188个Python源代码文件、60个可执行文件、39个HTML文件等多种类型。项目设计旨在...

Global site tag (gtag.js) - Google Analytics