一、js事件 

1、事件

  用户在网页中所触发的行为

  鼠标滑动种类很多,键盘、表单特列;

  点击:onclick

  鼠标进入:onmouseenter        鼠标离开:onmouseleave

  鼠标悬浮:onmouseover         鼠标移除:onmouseout

  鼠标按下:onmousedown        鼠标抬起:onmouseup

  鼠标移动:onmousemove

  表单聚焦:onfocus           表单失去焦点:onblur

  浏览器加载完成:onload

  js事件是一直存在的,可以绑定方法,也可以不绑定,如果没有绑定,事件都会发生,只是这个事件什么都没有,可以给相应的元素绑定事件和方法

  div . onclick=fiunction(){ } 点击div时就触发了函数中的代码块

2、事件对象

  一个事件触发获得的所有信息都在事件对象中保存着

3、事件源  event . target

  鼠标点在谁的身上,谁就是事件源

4、事件的使用方法

  (1)、事件 将事件当做标签属性使用

     eg:<img src="img/01.jpg"     alt="  "     onclick=alert(456)>

  (2)、通过事件绑定 将事件当成一个元素的属性

     eg:pic [0] . onclick=function() {

            alert(456)

             }

二、Js中的for循环和事件的关系

    事件的执行和for循环没有关系,都是相互独立的。

  1、解决事件中的i和for匹配

    方法一:给事件套一个自调用函数

        for (var i=0;i<arr.length;i++){

          (finction (i) {

              lis [ i ] .onlick=function ( ) {

                  tupian.src=arr [ i ]

                }

              })

            }

    方法二:人为定义属性,将索引在属性里需要的时候,调用属性(用this)

         for (var i=0;i<arr.length; i++){

            lis[ i ].index=i;

            lis [ i ].onclick=function () {

                tupian.src=arr [ this.index ]

                    }

                }

三、this

    This 是js的一个关键字,他是一个对象,一般用在函数里用于指向函数内部的关系。

    Div.onclick=function(){this}

    如果函数在定义的时候前面有.,那么this就指向点前面的对象。

    fn()

    如果函数定义时没有. 那么this就是window

js事件、Js中的for循环和事件的关系、this的更多相关文章

  1. js jq输入框中按回车触发提交事件,用户在页面输入后按回车(Enter键)进行

    js jq输入框中按回车触发提交事件,用户在页面输入后按回车(Enter键)进行 代码如下: <!DOCTYPE html> <html lang="en" xm ...

  2. js中当for循环中有事件要使用循环变量时,变量用var声明和let声明的区别

    var 声明一个全局变量,声明的变量会变量提升: let 声明一个局部变量: 当页面加载完后,for循环也结束了,如果用var声明的变量此时也随着for循环的结束而自增到满足结束循环的条件, 此时调用 ...

  3. 为什么js 的constructor中是无限循环嵌套:Foo.__proto__.constructor.prototype.constructor.prototype.constructor.prototype.xxx ?

    constructor始终指向创建当前对象实例的(构造)函数. 任何函数都是Function类的一个实例 那么根据上述可知:任何函数的constructor属性都指向Function类,而Functi ...

  4. Zepto.js touch模块深入分析 解决手机点击事件

    源码: // Zepto.js // (c) 2010-2015 Thomas Fuchs // Zepto.js may be freely distributed under the MIT li ...

  5. js和jquery中的事件委托

    [转+自己的修改] 概念: 什么是事件委托:通俗的讲,事件就是onclick,onmouseover,onmouseout,等就是事件,委托呢,就是让别人来做,这个事件本来是加在某些元素上的,然而你却 ...

  6. JS给元素循环添加事件的问题

    <ul> <li>男</li> <li>女</li> <li>老</li> <li>少</li&g ...

  7. js闭包理解案例-解决for循环为元素注册事件的问题

      转发自http://www.ruanyifeng.com/blog/2009/08/learning_javascript_closures.html       一.变量的作用域 要理解闭包,首 ...

  8. JS和jQuery中的事件总结(一)

    学而时习之,小白现在天天写页面,基础知识还是要恶补的. 进入正题,什么是事件(此处单独对jQuery.JS)?就是JS和Html之间的交互时呢,用户和浏览器操作页面时的动作(其实是为引发的效果的执行操 ...

  9. js和jquery中的触发事件

    改别人的坑,遇到jquery选择器和fireEvent混用,不认识fireEvent方法报错. js的方法不能使用jquery的选择器去调用. 1.fireEvent (IE上的js方法 ) 我们来看 ...

随机推荐

  1. TCO 2016 Round 1B

    problem 250 Problem Statement Vasa likes to construct sequences of numbers. If you tell him a positi ...

  2. seafile看不见repo报500错误的解决方法

    环境 seafile-server-6.2.5 centos7.5 1804 现象 seafile服务器所在的VPS没动过,前一天seafile用还好好的,昨天客户端突然不能登录了,显示“服务器内部错 ...

  3. HDU1569 方格取数(2) —— 二分图点带权最大独立集、最小割最大流

    题目链接:https://vjudge.net/problem/HDU-1569 方格取数(2) Time Limit: 10000/5000 MS (Java/Others)    Memory L ...

  4. laya在微信小游戏中加载BitmapFont失效的问题

    发布为微信小游戏后,在微信工具中测试时总是提示加载retry to load TheRed.fnt,并以error告终.由于没有任何出错信息,无奈之下只好阅读源码.对BitmapFont的处理分为两个 ...

  5. javascript之数组的6种去重方法

    去重 var arr=[11,11,333,4,4,5,66,66,7]; // 方法一:在新数组内判断不存在时加入 var newarr1=[]; function quchong1(){ for( ...

  6. Unreachable code

    Unreachable code 错误 不可达代码,比如在循环的break或者return后面的代码就是不可达代码,因为在执行它们之前就已经跳出方法了,只要把这段代码移到break或者return之前 ...

  7. 【iOS】KVC 和 KVO 的使用场景

    http://blog.csdn.net/chenglibin1988/article/details/38259865   Key Value Coding Key Value Coding是coc ...

  8. VC++、MFC

    VC++.MFC最好的开源项目 介绍:介绍一下用VC++/MFC写的最好的开源项目. Sourceforge.net中有许多高质量的VC++开源项目,我列举了一些可以作为VC++程序员的参考. 正文: ...

  9. Nginx: 统计PV、UV、独立IP

    1.概念: UV(Unique Visitor):独立访客,将每个独立上网电脑(以cookie为依据)视为一位访客,一天之内(00:00-24:00),访问您网站的访客数量.一天之内相同cookie的 ...

  10. Redis高级

    Redis高级 redis数据备份与恢复 Redis SAVE 命令用于创建当前数据库的备份. redis Save 命令基本语法如下: redis 127.0.0.1:6379> SAVE 实 ...