JS和CSS加载(渲染)机制不同

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS和CSS加载(渲染)机制不同相关的知识,希望对你有一定的参考价值。

一、结论

CSS可以在页面加载完成后随时渲染。举个例子:通过js给某个元素加一个id或者css,只要这个id或者css有对应的样式,此元素的样式就会自动生效。

JS不可以在页面加载完成后生效。最明显的例子就是使用EasyUI的时候,iframe中哪些样式无效(EasyUi是依靠JS进行样式处理的,所以无法运行JS,那么样式也就无法设置。简单点说:EasyUi是一个JS的前端框架,Bootstrap是一个CSS的前端框架,二者不同)。

二、现象

对于EasyUi那样的js核心的框架我没有想到办法,但是对于一些简单的时间还是可以处理的。

以下是我实际开发遇到的一个问题,我将其抽象出来:

某个按钮class为"tt"不是原生的html存在页面中的,而是通过页面加载过程中的JS生成的.

在最初我有如下语句:

$(".tt").click(function(){
     alert("xxx");
});

但是这个方法死活触发不了,根据上述第一点我的结论可知,这个是因为页面的JS已经加载完了,此时元素还没有生成。自然而言的无法有效的绑定事件。

那么怎么处理了?

<button onclick="mc-alert()">TELL</button>

将alert()放在方法mc-alert()中,即可。

三、深度剖析

小生水平不够,只能意味不能言传,也可以说是没有想明白,你懂,请不吝赐教。。。3Q。

以上是关于JS和CSS加载(渲染)机制不同的主要内容,如果未能解决你的问题,请参考以下文章

next.js中重复的CSS和Js渲染问题

thymeleaf 片段渲染后重新加载 javascript

js执行会阻塞DOM树的解析和渲染,那么css加载会阻塞DOM树的解析和渲染吗

js执行会阻塞DOM树的解析和渲染,那么css加载会阻塞DOM树的解析和渲染吗

前端性能优化 css和js的加载与执行

页面渲染机制