操作DOM

var newDOM=DOM元素.cloneNode(参数);

克隆(复制)当前节点,参数默认为false只复制当前节点元素。参数为true时复制当前元素及其后代和所有属性。

day06

1、函数封装中的默认值问题

  在函数定义后的调用过程中,如果函数需要有参数传入,而调用时传入参数不全,就会产生参数未定义的报错。

  解决方法可以在函数中为传入参数定义默认值。

function(x,y){
  x = x || "abc" ;
  y = y || "123" ;
}

" || ",或运算符会判断是否有x,y参数,如果有则赋值为x,y,如果没有则会赋值为或运算符后面的内容。

day08

1、

  可以给html标签添加自定义属性,并且可以用js获取到

方法:XXX.getAttribute("");XXX.setAttribute("")

注意:自定义属性不可以直接通过标签对象属性调用,标签对象直接调用属性只能是html标签自带属性。

2、

  JS不能获取行内样式之外的样式。

需要 getComputedStyle("xxx").width

顾名思义计算后的样式,因为浏览器解析页面和样式是分开的。

IE8及之前的版本不支持上述方法,需要用

getCurrentStyle("xxx").width

day09

1、懒了,截图

2、计算属性

  可以通过计算属性获取可以直接使用的属性值(纯数字):offsetWidth、offsetHeight、offsetTop、offsetLeft

  每次获取时才计算出位置,不固定,无法修改只能实时获取属性值。

  offsetParent可以直接获取有定位的父元素,即子元素定位的参照元素。

3、文档碎片

  var frag = document.createDocumentFragment();

  创建一个文档缓存,用于暂时存储新创建的元素。

4、鼠标事件

  兼容写法:IE8及以下版本中鼠标事件event存在window下。

function(evt){
  var e = evt || event ;  
}

获取鼠标位置的几个属性:

offsetX,offsetY 相对于触发事件的元素中的位置

clientX,clientY 相对于当前可视区域中的位置

pageX,pageY 相对于整个页面中的位置

注意pageX,Y有兼容问题,IE8及之前版本和火狐老版本不支持

5、

找到元素之后可以通过     元素.aaa=xxx; 在内存中给元素添加值为xxx的aaa属性;

day10

1、阻止默认事件

  通知浏览器不要执行与事件关联的默认动作。

  e.preventDefault(); IE8以下不支持

  兼容IE8及以下

  e.returnValue=false;

  兼容写法: e.preventDefault ? e.preventDefault() : e.returnValue=false ;

2、阻止右键菜单

  点击右键触发的函数  document.oncontextmenu = function (){ }

  添加上述阻止默认事件即可。

3、阻止事件传播

  e.stopPropagation();阻止事件向上传播。

  兼容IE写法:

  e.stopPropagation ? e.stopPropagation() : e.cancleBubble = true ;

day11

1、事件的冒泡和事件的捕获

  事件的捕获是指事件触发后从顶层元素向下传播,直到最底层。

  捕获事件写法:addEventListener("事件",true);(第二个参数决定该事件是冒泡还是捕获,默认值是false,冒泡)

  捕获事件同样可以使用阻止事件传播的方法阻止。

  当多层结构中捕获现象和冒泡现象同时存在时:先执行捕获事件,再执行冒泡事件。

  当同一个元素上捕获现象和冒泡现象同时存在时,会按照代码顺序执行。

  addEventlistener()方法不会互相覆盖,同一个元素可以绑定多个相同的事件不冲突。执行顺序按照代码顺序。

2、事件代理

  简单理解:将本该自身触发的事件方法“代理(委托)”给父元素或更高层级元素,利用事件的冒泡来触发被“代理”的事件,达到预期的效果。

  e.target()方法可以返回触发该事件的元素对象。

  兼容写法:

  var target = e.target || e.srcElement ;

  事件代理可应用于子元素数量很多的情况。例如下拉选择菜单中的单击事件。

3、onmouseenter 和 onmouseleave 事件

onmouseenter 事件类似于 onmouseover 事件。 唯一的区别是 onmouseenter 事件不支持冒泡

课堂小记---JavaScript(3)的更多相关文章

  1. 课堂小记---JavaScript(4)

    day11 1.正则表达式 去掉首尾的空格或者其他字符 replace方法可传入函数可分组. 以下为分组 基础正则表达式语法: /** * 正则表达式是一个对象类型 */ // 匹配字符串中的che ...

  2. 课堂小记---JavaScript(2)

    本阶段难点疑点梳理 1.关于switch中default的使用: default同case功能一样,区别在于并不匹配任何信息,只有当case中无任何匹配的时候才会执行default.需要注意的是,这是 ...

  3. 课堂小记---JavaScript(1)

    day01 1.数据类型  number string boolean undefined object function 加号具有两种功能,数字相加 和 字符串拼接.加号两边只要碰见字符串,则执行字 ...

  4. 杨校老师课堂之JavaScript右下角广告弹框教程

    案例制作思路: 1.先制作界面 添加一个盒子包含一个按钮,使盒子绝对定位在右上角 添加一个大盒子,同理,将盒子居于左下角:其中内部包含一个顶端盒子和底部盒子 顶端盒子因为是属于大盒子内部的存在,所以宽 ...

  5. 杨老师课堂之JavaScript定时器_农夫山泉限时秒杀案例

    预览效果图: 使用到的知识点: 定时器 setInterval(函数,毫秒):在指定的毫秒数后调用函数或执行一段代码 取消定时器 clearInterval:取消由setInterval设置的定时器 ...

  6. javascript小记-javascript运行机制

    任何语言的运行过程中,都会有编译和执行: 对于传统编译型语言来说,编译步骤分为:词法分析.语法分析.语义检查.代码优化和字节生成.但对于解释型语言来说,通过词法分析和语法分析得到语法树后,就可以开始解 ...

  7. 松软科技Web课堂:重要->JavaScript 调试

    错误总会发生,每当您写一些新的计算机代码时. JavaScript 调试 在没有调试器的情况下写 JavaScript 是有难度的. 您的代码中也许包含了语法错误,或者逻辑错误,这些都难以诊断. 通常 ...

  8. 松软科技前端课堂:JavaScript 数值方法

    Number 方法帮助您处理数值. Number 方法和属性 原始值(比如 3.14 或 2016),无法拥有属性和方法(因为它们不是对象). 但是通过 JavaScript,方法和属性也可用于原始值 ...

  9. 松软科技前端课堂:JavaScript 对象

    真实生活中的对象.属性和方法 在真实生活中,汽车是一个对象. 汽车有诸如车重和颜色等属性,也有诸如启动和停止的方法: 对象 属性 方法   car.name = porsche car.model = ...

随机推荐

  1. 1.8分布式集群模式基础(VM安装多台服务器)

    前言 一晃就是10几天,学习的过程是断断续续的,对个人来说,这并不是一个良好的状态.在这10几天了,迷恋起了PS... 从今天起,坚持一周4篇,额.希望吧 在之前的随笔中,我安装了Xshell 和 C ...

  2. sql server登录名、服务器角色、数据库用户、数据库角色、架构区别联系

    原创链接:https://www.cnblogs.com/lxf1117/p/6762315.html sql server登录名.服务器角色.数据库用户.数据库角色.架构区别联系 1.一个数据库用户 ...

  3. linxu下redis安装实战

    redis官网地址:http://www.redis.io/ 最新版本:2.8.3 在Linux下安装Redis非常简单,具体步骤如下(官网有说明): 1.下载源码,解压缩后编译源码. $ wget ...

  4. 【ARC 063F】Snuke's Coloring 2

    Description There is a rectangle in the xy-plane, with its lower left corner at (0,0) and its upper ...

  5. MySQL保留字不能作为字段名使用

    在设计MySQL字段的时候,无意中使用InOut这个名称作为字段名称,结果前端提交后就是没有写入数据库!但后端没有任何提示,跟踪mySQL日志,也没有留下痕迹,反复查,不得其解. 后来实在没有办法情况 ...

  6. springboot整合springdata-jpa

    1.简介  SpringData : Spring 的一个子项目.用于简化数据库访问,支持NoSQL 和 关系数据存储.其主要目标是使数据库的访问变得方便快捷. SpringData 项目所支持 No ...

  7. 医学图像数据(三)——TCIA部分数据下载方式

    前为止,本人还没有找到不需要账号的就可以部分下载的方式,因此这里讲的是需要注册账号下载部分数据的方法. 注意:下载部分数据需要注册账号 注册账号网址:https://public.cancerimag ...

  8. pwnable.tw silver_bullet

    产生漏洞的原因 int __cdecl power_up(char *dest) { char s; // [esp+0h] [ebp-34h] size_t new_len; // [esp+30h ...

  9. Go语言--数组、切片、

    3.1 数组--固定大小的连续空间 3.1.1 声明数组 写法 var 数组变量名 [元素数量]T 说明: 变量名就是使用时的变量 元素的数量可以是表达式,最后必须为整型数值 T 可是是任意基本类型, ...

  10. 部署自建CA颁发证书实现https加密

    理论忽略:百度上很多 需求:自建证书并实现域名的https加密 部署: 在linux机器上执行以下命令生成私钥 mkdir -p /opt/ssl-cert cd  /opt/ssl-cert 1.# ...