前端:JS/28/CSS DOM动态样式(style对象,style 对象属性与CSS属性的转换),Event DOM,事件对象简介(DOM和IE中的Event对象),实例:点出满天小星星

CSS DOM动态样式

使用JS操作CSS中的各个属性;
JS只能操作或修改行内样式,如:imgObjstyle.border = “1px solid red”;
对于类样式,通过className 来赋值,如:imgObjclassName =“imgClass”;

style 对象

每个HTML标记,都有一个style属性;但这个style属性又是一个style对象;是CSS行内样式;
这个style对象的属性与CSS中的属性一一对应,完全相同;
例:imgObj.style.border =“1px solid red”;

style 对象属性与CSS属性的转换

1,如果是一个单词,style对象,与CSS属性一样;
2,如果是多个单词,第1个单词全小写,后面每个单词首字母大写,并去掉中划线;
例:divObj.style.backgroundColor=“red”;
divObj.style.backoundImage=“url(images/td.jpg)”;

Event DOM :事件DOM

1,事件简介

1

2,常用事件

2

3,事件句柄属性

HTML标记,都有自己相应的事件属性;
每个HTML标记,都对应一个元素对象,元素对象也具有相应的事件属性;
但是,元素对象的事件应该全都小写;
事件属性后面调用的一般是JS函数,通过函数来完成相应的功能;

Event 对象简介

当事件发生时,向要调用的函数,传递一个event参数,这个event参数是一个事件对象;即事件一发生便产生了event对象参数;且默认存在于第一个参数;该event对象中记录了当前事件发生时的环境信息,如:单击时的坐标,事件类型等;
注意:这个event对象是“短暂存在的”,新的事件发生,新的event对象产生,原来的event对象就消失了;

DOM中的Event对象

1,DOM中引入Event对象(DOM浏览器就是浏览器)
(1),通过HTML标记的事件属性来传递event对象;
在DOM中,event对象是作为事件调用函数时的参数,传递给函数的;
该event参数,是系统固定写法,全小写,不能加引号,它就是event对象参数,event参数包含此事件发生时所有的环境信息;
3
(2),使用元素对象的事件属性来传递event对象
4

DOM 中Event对象的属性

type :当前的事件类型;
pageX 和 pageY :距离网页左边和顶部的距离;
clientX 和 clientY :距离窗口左边和顶部的距离;
screenX 和 screenY :距离屏幕左边和顶部的距离;

IE中的Event对象

在IE中window对象下存在一个event属性从而代替了事件的event对象参数;
5

IE中Event对象属性

6

实例:点出满天小星星

<!DOCTYPE html>
<html lang="en" οnclick="init(event)">
<!-- 点击网页时触发init(event)函数 -->

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>JS事件实例_点出满天小星星</title>
    <script type="text/javascript">
        function init(e) {
            document.body.bgColor = "#000";//网页背景为黑色
            var img = document.createElement("img");//生成星星图片对象
            document.body.appendChild(img);//把img对象追加到body上
            img.setAttribute("src", "images/th11.jpg");//img添加属性
            var width = getRandom(1, img.width);//图片随机大小
            img.setAttribute("width", width + "px");//图片随机大小
            var x = e.clientX - width / 2; var y = e.clientY - width / 2;//获取点击的位置距窗口的X,Y坐标
            img.setAttribute("style", "position:absolute;left:" + x + "px;top:" + y + "px;");//设置img的定位
        }
        function getRandom(min, max) {
            var random = Math.random() * (max - min) + min;
            random = Math.floor(random);
            return random;
        }
    </script>
</head>

<body>

</body>

</html>

显示效果如下:
7

@沉木

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 不同框架对于DOM节点的检索优化方式会有所不同。以下是几种常见的框架及其优化方式: 1. jQuery:jQuery的选择器引擎Sizzle优化了节点检索,通过尽可能减少比较操作来提高性能。Sizzle会先尝试使用浏览器原生的querySelectorAll方法,如果不支持则使用自己的实现。 2. React:React采用了虚拟DOM技术,即将真实的DOM节点抽象成一个虚拟的JavaScript对象,使得对DOM的操作变成了对JavaScript对象的操作,从而减少了对真实DOM的访问次数,提高了性能。 3. AngularJS:AngularJS通过数据绑定机制使得DOM操作最小化,只有在数据变化时才进行DOM操作。此外,AngularJS还提供了一些指令(如ng-repeat)来优化循环操作,避免重复的DOM操作。 4. Vue.js:Vue.js也采用了虚拟DOM技术,但是与React不同的是,Vue.js对于每个组件都维护了一个独立的虚拟DOM树,使得只有当组件数据发生变化时才会重新渲染,从而提高了性能。 总的来说,不同框架的优化方式都是为了减少对真实DOM的访问次数,尽可能减少不必要的DOM操作,从而提高性能。 ### 回答2: 在页面往服务器端传输期间,如果需要检索DOM对象每个节点的值,不同框架会采取不同的优化方式。 首先,DOM(文档对象模型)是用于表示和操作HTML或XML文档的标准。在传统的JavaScript,通过getElementById、getElementsByTagName等方法来获取DOM对象,然后逐个节点进行值的检索。这种方式简单直接,但效率较低,因为需要遍历整个DOM树。 为了优化DOM节点的检索效率,一些现代前端框架引入了虚拟DOM(Virtual DOM)的概念。虚拟DOM是在内存DOM的抽象表示,通过算法比较虚拟DOM的差异,然后只更新变化的部分。这种方式减少了DOM操作的数量,提高了性能。 另外,一些框架还提供了选择器引擎,如jQuery的Sizzle引擎,可以根据CSS选择器快速定位和检索DOM节点。通过这种方式,可以更方便地获取特定条件下的节点值。 除了选择器引擎外,还有一些优化方法也可以使用。例如,在某些情况下,可以将DOM节点的值存储在数据结构进行缓存,减少对DOM树的频繁访问。此外,可以合理利用Event Delegation机制,将事件处理程序注册在DOM的父级节点上,从而减少事件处理程序的数量,提高性能。 总之,不同框架对DOM对象的检索优化方式不尽相同,但都旨在提高效率。通过引入虚拟DOM、选择器引擎和其他一些优化技术,可以减少对整个DOM树的遍历,从而提升页面性能和用户体验。 ### 回答3: 在页面往服务器端传输数据时,我们经常需要检索DOM对象每个节点的值。不同框架在这方面的检索优化方法可以有以下几种: 1. 缓存节点查询结果:为了避免多次查询同一个节点,在第一次查询节点时,可以将查询结果缓存在某个变量,以后再次需要查询该节点时,直接使用缓存结果,避免了不必要的查询操作。 2. 使用选择器引擎:许多框架提供了选择器引擎,通过使用选择器来选择和查询DOM节点,可以提高检索的效率。这是因为选择器引擎底层会使用更高效的算法来查询和匹配DOM节点,相比于手动编写查询代码,使用选择器引擎可以简化操作,提高性能。 3. 使用事件委托:事件委托是一种优化DOM操作的方法,它利用了事件冒泡的机制。通过将事件绑定到父节点上,而不是绑定到子节点上,可以减少事件绑定的数量,从而提高性能。当子节点触发事件时,事件会冒泡至父节点,通过判断触发事件的子节点来执行相应的操作,避免了对每个子节点都进行事件绑定。 4. 使用虚拟DOM:一些现代框架,如React和Vue,使用虚拟DOM来优化DOM操作。虚拟DOM是在内存对真实DOM的一种抽象表示,通过比对虚拟DOM和真实DOM的差异,最小化对真实DOM的操作,从而提高性能。 总之,不同框架通过缓存结果、使用选择器引擎、使用事件委托和使用虚拟DOM等方法来优化DOM对象的检索操作,提高性能和用户体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值