知识点总结:

  • 鼠标滚轮事件

存在兼容性问题:
  IE/chorme : onmousewheel
  FF : DOMMouseScroll,必需用在addEventListener下,例如:

if (obj.addEventListener) {
obj.addEventListener('DOMMouseScroll',fn,false);
}

注:addEventListener也需要做兼容,该方法在FF和chorme有效,在IE中是attachEvent

滚轮属性:
  IE/chorme:
    ev.wheelDelta
      下:-120
      上:120

  FF:
    ev.detail
      下:3
      上:-3

考虑到兼容性,通过布尔值为进行兼容的处理

        var oDiv = document.getElementById('div1');
var b = true; //默认方向:向下 //事件绑定兼容
var bind = function(obj,eventName,eventFn){
if (obj.addEventListener){
obj.addEventListener(eventName,eventFn,false);
} else {
obj.attachEvent('on'+eventName,function(){
eventFn.call(obj);
});
}
};
//获取方向
var getDir = function(dir){
if (dir){
return '向下';
} else {
return '向上';
}
}; if (oDiv.addEventListener){
bind(oDiv,'DOMMouseScroll',function(ev){
//firefox:下(3) 上(-3)
var ev = ev || event;
b = ev.detail>0 ? true : false;
console.log(getDir(b));
});
bind(oDiv,'mousewheel',function(ev){
//IE和chrome: 下(-120) 上(120)
var ev = ev || event;
b = ev.wheelDelta<0 ? true : false;
console.log(getDir(b));
});
}

如果阻止鼠标的默认行为:
  IE/chorme : return false
  FF :
    obj.onclick = fn =>return false;
    obj.addEventListener('click',fn,false) => ev.preventDefault();

    兼容处理:

            if(ev.preventDefault) {
ev.preventDefault();
}
  • cookie

1、cookie以域名的形式来存放的
2、一个域名下存放的cookie个数有限制,不同浏览器存放的个数不一样
3、cookie的内容大小也有限制,不同浏览器存放大小不一样
4、cookie默认是临时存放的,即浏览器关闭消失(注:不是选项卡)
5、cookie存放格式: document.cookie = "名字=值" 获取cookie,即alert(document.cookie),显示结果把当前网站所有的cookie显示出来,并用分号+空格的形式串联起来 例如:
document.cookie = "username=joya"
document.cookie = "age=11"
alert(document.cookie) =>结果为username=joya; age=11 document.cookie="名字=值;expires="+字符串格式的时间 即:
var oDate = new Date(); 获取当前时间
oDate.setDate(oDate.getDate()+7); //cookie存放7天,setDate(18)表示设置日期18号,通常cookie的使用是当前的时间+几天,因此用getDate来获取当前日期+多少天
document.cookie = "username ="+ encodeURI("\njoya") +";expires=" + oDate.toGMTString();
//注:1、需要是字符串格式的时间,oDate是对象,需要进行转换,即toGMTString
   2、内容最好编码存放,即encodeURI('值'),与这个相反的有decodeURI('编码')   alert(decodeURI(document.cookie));
  • 封装cookie(增加setCookie,读取getCookie,删除removeCookie)

见js框架

  • localStorage

localStorage.getItem('rd_lang')  获取

localStorage.setItem('rd_rang')  设置

[妙味DOM]第六课:鼠标滚轮和COOKIE的更多相关文章

  1. [妙味DOM]第五课:事件深入应用

    知识点总结 鼠标拖拽原理: 1.鼠标按下后开始移动,鼠标抬起停止移动,即onmousedown中要包括onmousemove和onmouseup 2.获取位置的计算:获取鼠标的当前位置-鼠标在物体中的 ...

  2. [妙味DOM]第四课:Event-事件详解2

    知识点总结 事件捕获 obj.addEventListener('click',fn,true) 从外往里 obj.addEventListener('click',fn,false) 从里往外(冒泡 ...

  3. [妙味DOM]第三课:Event-事件详解1

    知识点总结 焦点事件 onfocus 获取焦点 onblur 失点焦点 obj.focus() 给指定元素设置焦点 obj.blur() 取消指定元素的焦点 obj.select() 选择指定元素里的 ...

  4. [妙味DOM]第一课:DOM基础概念、操作

    知识点总结 childNodes.children子节点列表集合.nodeType节点类型.nodeName.nodeValue.attributes属性列表集合 childNodes和childre ...

  5. [妙味 DOM] 第二课:DOM、BOM相关方法及属性

    知识点总结 获取样式.增加样式.删除样式函数的封装 表格 tHead tBodies tFoot rows 行 cells 列 表单 表单可以通过name来获取元素:表单.name值 onchange ...

  6. [妙味Ajax]第三课:AJAX跨域解决方案:JSONP

    知识点总结: JSONP(JSON with Padding): 1.script标签 2.用script标签加载资源是没有跨域问题的 在资源加载进来之前定义好一个函数,这个函数接收一个参数(数据), ...

  7. [妙味JS基础]第九课:定时器管理、函数封装

    知识点总结 函数封装 回调函数 实例:抖动函数 获取当前的位置 通过数组来实现,一正一负,直到恢复成0为止. 当前位置与数组中各值相加

  8. [妙味JS基础]第二课:for应用、this关键字

    知识点总结 getElementsByTagName(动态方法) 与 getElementById(静态方法) 的区别 1.ID前面只能跟document,不能跟其他元素,比如:document.ge ...

  9. [妙味JS基础]第一课:属性操作、图片切换、短信发送模拟

    知识点总结 HTML的属性操作:读.写 元素.属性名 => “读” 元素.属性名=新的值 => “写” 例如: oBtn.value => “读” oBtn.value='按钮' = ...

随机推荐

  1. Winsock - 1 - Winsock API

    Winsock Winsock API Winsock是网络编程接口,而不是协议. 网络原理和协议 建立Winsock规范的主要目的是提供一个与协议无关的传送接口. Winsock将网络编程接口与具体 ...

  2. solr常用命令

    1.启动和关闭 a.启动和重启 启动和重启命令有很多选项让你运行在SolrCloud模式,使用示例配置,以hostname为开头或者非默认端口,指向本地ZooKeeper. bin/solr star ...

  3. mybatis学习笔记二(接口注解)

    直接上代码,全部在代码里讲解. 1.实体类 package com.home.entity; /** * 此类是:user实体类 * @author hpc * @2017年1月10日下午9:36:5 ...

  4. class.forname()方法的学习(转)

    Class.forName(xxx.xx.xx) 返回的是一个类 首先你要明白在java里面任何class都要装载在虚拟机上才能运行.这句话就是装载类用的(和new 不一样,要分清楚). 至于什么时候 ...

  5. apk反编译查看源码

    1.将apk解压

  6. quagga源码分析--通用库thread

    quagga是开源路由器软件,提供的用户界面与思科,华为的路由器的人机接口几乎一致,非常有学习价值,尤其是开源的协议代码,简直亮瞎了我的小眼睛. quagga的介绍,我就不赘述了,有兴趣的可以找度娘或 ...

  7. Android之HandlerThread

    HandlerThread详解 1 HandlerThread基本原理 HandlerThread继承自Thread,它是一种可以使用Handler的Thread.它的实现很简单,就是在run方法中通 ...

  8. js得到当前页面的url信息方法

    js得到当前页面的url信息方法:http://www.cnblogs.com/zuosong160522/p/5755615.html js获取url传递参数,js获取url?后面的参数:http: ...

  9. node + express 资料

    https://www.youtube.com/watch?v=65a5QQ3ZR2g&list=PL55RiY5tL51oGJorjEgl6NVeDbx_fO5jR https://www. ...

  10. [SOJ]统计数字

    Description 某次科研调查时得到了n个自然数,每个数均不超过1500000000(1.5*10^9).已知不相同的数不超过10000个,现在需要统计这些自然数各自出现的次数,并按照自然数从小 ...