js中的事件(下)

1、阻止浏览器的默认行为  
  右键单击浏览器,会弹出一个菜单
  拖拽文字
  超链接 空链接--刷新   
  submit按钮 刷新页面
  阻止浏览器的默认行为 :
    e.preventDefault ? e.preventDefault() : e.returnValue=false;
 
2、事件绑定  -- 如何为某个元素添加某个事件
  1)<input type='button' onclick = 'fn()'>
  2)obj.onclick = function(){
    }
  3)通过  addEventListener()   绑定事件   ----  事件监听 
    用法 :obj.addEventListener("事件去掉on",function(){})   
      第一个参数  事件  
      第二个参数  事件处理程序
      第三个参数  布尔值  默认  false   控制事件冒泡还是事件捕获    true -- 事件捕获
  事件监听的好处 :  可以为同一个对象添加多个同样的事件 
                 可以根据事件监听的方法确定到底是事件的冒泡还是事件捕获 
 
  了解  : ie的事件监听:  attachEvent()   不能实现捕获
    obj.attachEvent("onclick",function(){
 
    })
3、事件冒泡和事件捕获的执行顺序(扩展)
  如果一个元素 既有事件冒泡,又有事件捕获,先捕获 后冒泡
4、js事件委托
  事件委托 : 又叫事件代理 ,将事件添加到某些元素的父元素或者祖先元素元素上  委托父级或祖先元素完成事件操作
  事件委托机制 :js事件委托,其实是使用了冒泡的原理,从点击的元素开始,会向父元素传播事件
 
  这样做的好处
    1)对于大量要处理的元素,不必为每个元素都绑定事件,只需要在他们的父元素上绑定一次即可,提高性能。
    2)可以处理动态插入dom中的元素,直接绑定的方式是不行的
  获取事件源:
      target = e.target || e.srcElement
 
5、json对象 
  json作用 : 存储数据    跨平台的数据存储格式   轻量级存储数据 --- 存储数据量小
  相对于普通的js{对象}来说,
    区别1:属性名字需要用双号号包含,
    区别2: 属性值如果是字符串那么也使用双引号。
  json数据的存和取  
    定义json : 
      var json = { "键":"值","键":"值",.... } 
    json值的获取 : 
        json对象.键 
        json对象["键"]
  json的遍历 : json没有length属性,不能用for循环遍历   只能用for...in  遍历
 
  json中的值可以是数组
        var json = {
           "url" : ["1.jpg","2.jpg"],
            "con" : ["图片一","图片二"]
        }
      for..in 中嵌套for
 
  数组中存放json : 
       [{"uname":"uname","pwd":111},{"uname":22,"pwd":22},{"uname":33,"pwd":999}]
       for 循环中嵌套for .. in
6、拖拽
  拖拽思路 : 
      涉及的事件 --- onmousedown   onmousemove   onmouseup
  1)要想实现拖拽效果,首先要有鼠标按下事件  
    记录鼠标按下时的内部偏移量
      var disx = e.offsetX  ||  e.layerX
      var disy = e.offsetY  ||  e.layerY
  2)鼠标移动  
    设置被拖拽物体的left和top值
      left = e.pageX - disx
      top = e.pageY - disy
  3)鼠标抬起 
    取消鼠标移动事件
      document.onmousemove = null  /  ""
  获取窗口的宽度和高度:  window.innerWidth / window.innerHeight  
7、scorll家族属性
  scrollTop : 获取页面垂直方向滚走的距离
  scrollLeft :  获取页面水平方向滚走的距离
  一般scrollTop 与 滚动条事件连用
    window.onscroll = function(){
      获取页面滚走的距离:
        document.body.scrollTop || document.documentElement.scrollTop
    }
8、盒子模型
  offsetWidth : clientWidth + 左右border
  offsetHeight : clientHeight + 上下border
  offsetTop : 元素的外边框距离offsetParent的内边框的垂直偏移量
  offsetLeft : 元素的外边框距离offsetParent的内边框的水平偏移量
  offsetParent : dom元素的offsetParent的值是谁,取决于它的祖先元素是否有定位属性(absolute,relative,fixed)。
        如果有这个定位属性那么直接offsetParent就获取这个。否则没有定位属性,那么继续上上一级祖先元素去查找。如果查找到body的所有祖先元素都没有定位属性。直接把body获取到。
  扩展 
    clientWidth : 内容+左右padding
    clientHeight : 内容+上下padding
    clientTop : 上边框的宽度
    clientLeft : 左边框的宽度
原文地址:https://www.cnblogs.com/ginelle/p/10239829.html