JS高度融合入门笔记(二)
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>JS2</title>
<style type="text/css">
#d1{
height: 100px;
width: 100px;
background-color: red;
position: absolute;
top: 0;
left: 0;
transition-delay: 0s;
transition-duration: 6s;
transition-timing-function: linear;
transition-property:all;
}
</style>
</head>
<body>
<div style="border: solid 5px blue;">
<div style="height: 50px;"></div>
<div id="aa"></div>
</div>
<textarea id="t"></textarea>
<button id="btn">点一下</button>
<div id="dd"></div>
<div id="d1"></div>
<script type="text/javascript">
//距离问题
var a = document.getElementById('aa');
console.dir(a);
//clientHeight = 内边距 + height(实际尺寸) 不含滚动轴的宽度
//offsetHeight = 内边距 + height + 边框宽度
//scrollHeight = 如果滚动条出现,则是可滚动的极限高度。如果没有滚动条,高度和clientHeight一样
a.clientHeight;
a.clientWidth;
a.offsetWidth;
a.offsetHeight;
a.offsetTop;
a.clientTop
a.scrollTop;
a.scrollWidth;
a.scrollHeight;
//鼠标的距离
//鼠标点击事件发生的时候"点击点"距离浏览器左上角的距离
//如果有滚动距离,该距离不含滚动距离,知识相对看到的区域左上角的位置
var i = document.getElementById('dd');
i.onclick = function (xxx) {
event.clientX;
event.clientY;
event.pageX;
event.pageY;
event.target;
event.toElement;
}
//按键事件及按键判断
document.onkeydown = function(){
var d1 = document.getElementById('d1');
if (event.key == 'd') {
d1.style.left = d1.offsetLeft + 100 + 'px';
}
if (event.key == 'a') {
d1.style.left = d1.offsetLeft - 100 + 'px';
}
if (event.key == 's') {
d1.style.top = d1.offsetTop + 100 + 'px';
}
if (event.key == 'w') {
d1.style.top = d1.offsetTop - 100 + 'px';
}
}
//JS有两种流:捕获流和冒泡流
//捕获流:最外层最先接收的事件,然后逐级向下传播,知道传到具体的元素对象上
//冒泡流:最内层(最具体的元素)最先接收到事件,然后逐级向上传播,知道最外层
//HTML事件就是事件以及事件的处理程序和html混写在一起
//DOM 0级事件
d1.onclick = f1;
//清楚DOM 0级事件
d1.onclick = null;
//DOM 2级事件
//可以为一个对象添加多个相同的事件处理程序,执行顺序按照代码先后顺序执行
//参数1:事件类型(不带on)
//参数2:事件的处理程序
//参数3:表示添加事件的时机,为true时表示在捕获阶段添加事件,false表示在冒泡阶段添加事件
d1.addEventListener('click',f1,true);
d1.addEventListener('click',f2,true);
//移出DOM 2级事件处理程序(参数和绑定时的一致)
d1.removeEleventListener('click',f1,true);
//IE事件模型
//添加事件(只在冒泡阶段添加),该方法也可以为一个对象添加多个相同事件
//参数1:事件类型(带on)
//参数2:事件的处理程序
d1.attachEvent('onclick',f1);
d1.attachEvent('onclick',f2);
//移除事件
d1.detachEvent('onclick',f1);
//兼容性处理
//思路:考虑多种浏览器的具体情况,然后统一封装,方便后期维护
//event事件
var d1 = document.getElementById('d1');
d1.onclick = function(e){
//event对象只有在事件发生的时候才会产生
//事件对象其实会默认传入到事件处理程序中
alert(e)
//获取事件的时候,使用这样的操作进行兼容的获取对象方法
}
//防止事件冒泡
e.stopPropagation();
//IE
window.event.cancelBubble = true;
//委托绑定
//利用事件的冒泡特性,将本来该绑定到具体的元素的事件委托给其上级对象进行绑定
var u = document.getElementById('u');
u.addEventListener('click',function(){
console.log(event.target.innerHTML);
console.log(this);
})
//Window对象
window.innerHeight;
window.innerWidth;
window.open();
window.print();
window.close();
window.confirm();
window.prompt();
window.scrollTo(100,500);
window.name;
window.self;
window.parent;
window.document.(...);
</script>
</body>
</html>
JS高度融合入门笔记(二)的更多相关文章
- JS高度融合入门笔记(一)
复制下面的代码到编辑器里,让编辑器自动排版一下格式,效果会好一点,自我感觉我笔记的条理还是比较容易记忆的 <!DOCTYPE html><html><head> & ...
- 纯JS实现KeyboardNav(学习笔记)二
纯JS实现KeyboardNav(学习笔记)二 这篇博客只是自己的学习笔记,供日后复习所用,没有经过精心排版,也没有按逻辑编写 这篇主要是添加css,优化js编写逻辑和代码排版 GitHub项目源码 ...
- onethink入门笔记(二)
5.onethink页面端获得后台服务器传值的方法 1:一般后台通过assign的值前台通过{$value}显示出来; 2:如果需要在js中使用 则可以通过 在js中写 var m = "{ ...
- nodeJs入门笔记(二)
js中window通常是全局变量 global 是node.js里的全局变量 node中能访问的对象一般都是 global的 属性 global 对象属性 process 用于描述当前Node 进程状 ...
- Shader 入门笔记(二) CPU和GPU之间的通信,渲染流水线
渲染流水线 1)应用阶段(CPU处理) 首先,准备好场景数据(摄像机位置,视锥体,模型和光源等) 接着,做粗粒度剔除工作. 最后,设置好每个模型的渲染状态(使用的材质,纹理,shader等) 这一阶段 ...
- OpenGLES入门笔记二
#import <UIKit/UIKit.h> #import <QuartzCore/QuartzCore.h> #import <OpenGLES/ES2/gl.h& ...
- Redis入门笔记(二)-配置及运行
转自: http://gly199.iteye.com/blog/1056424 1.redis基本参数 redis的配置文件中的常见参数如下: daemonize 是否以后台进程运行,默认为no ...
- Scala入门笔记二
[TOC] 标识符 可用的字符 处理括号类字符,分隔符之外,其他所有的可打印的ASCII字符,如字母,数字,下划线和美元符号($)均可出现在Scala标识符中 插入符包括了(,) [,] {,and} ...
- Shader 入门笔记(二) CPU和GPU之间的通信
渲染流水线的起点是CPU,即应用阶段. 1)把数据加载到显存中 2)设置渲染状态,通俗说这些状态定义了场景中的网格是怎样被渲染的. 3)调用DrawCall,一个命令,CPU通知GPU.(这个命令仅仅 ...
随机推荐
- html的标签(1)
首先补充上一次没有讲到的,html文件后缀名有2种,一种是.htm,一种是.html..html是老的教科书里面的文件后缀名,.html是新的教科书的文件后缀名..htm文件是不完整的支持html5的 ...
- SQL Server数据类型一览表
数据类型 类型 描 述 bit 整型 bit 数据类型是整型,其值只能是0.1或空值.这种数据类型用于存储只有两种可能值的数据,如Yes 或No.True 或Fa lse .O ...
- iPython与notebook的基本用法
1 Ipython 安装 pip install ipython 2 Notebooke 基本用法 启动ipython使用ipython 启动notebook 使用 ipython notebook ...
- 基于ArcGIS Runtime 100.x 的移动应用程序开发框架 开源
ArcGIS Runtime作为新一代的轻量GIS应用开发产品,它提供多种API,可以使用Android,iOS,Java,Mac OS X(Objective-C/Swift)..NET,Qt(C+ ...
- Jenkins新建节点,启动方式没有“通过Java Web启动代理”选项怎么办?
在Jenkins中,打开“系统管理”→“管理节点”→“新建节点”页面时,“启动方式”选项没有“通过Java Web启动代理”,怎么办? 打开“系统管理”,进入“全局安全配置”页面. 1. “JNLP代 ...
- Div+Css布局教程(-)CSS必备知识
目录: 1.Div+Css布局教程(-)CSS必备知识 注:本教程要求对html和css有基础了解. 一.CSS布局属性 Width:设置对象的宽度(width:45px). Height:设置对象的 ...
- matlab练习程序(弧形投影)
这个其实也算是圆柱体投影了,不过上一篇文章是从正面看,得到的是凸形的结果,而这个是从反面看,得到的是凹形的结果. 计算公式就不写了,大致介绍一下,计算公式中关于x坐标求法和上篇一样,y坐标则正好是上篇 ...
- Java web的安全约束--Basic验证
要进行basic验证是用户名/口令机制,当浏览器要访问受保护的资源时,服务器会要求一个用户名和口令,只有输入了合法的用户名和口令.服务器才发送资源.用户名和口令可以存储在安全域中.安全域是标识一个We ...
- Filter学习总结,顺便提及点servlet3.0异步filter和异步监听
Filter介绍: Filter在项目中经常可以用到,通常配置在web.xml中.是服务器端的一个组件,对于用户的请求和响应数据进行过滤操作,控制是否让用户访问到对应的web资源.常用于编 ...
- 【Hibernate那点事儿】—— Hibernate应该了解的知识
前言: 最近由于有点时间,就像深入的学习一下Hibernate.之前只是简单的使用,并没领会它的妙处.这里就趁着分享的机会,好好整理一下. 这篇主要讲到了下面几个部分: Hibernate框架 Hib ...