zoukankan      html  css  js  c++  java
  • JavaScript、jQuery、HTML5、Node.js实例大全-读书笔记3

    技术非常多,样例非常多。仅仅好慢慢学,慢慢实践!!如今学的这本书是【JavaScript实战----JavaScriptjQueryHTML5Node.js实例大全】

    JavaScript、jQuery、HTML5、Node.js实例大全-读书笔记2

    3.3 响应鼠标动作

    图3-2的效果已经有了,须要鼠标来操作展示想看的照片。这就须要在对应的地方加上事件。

    3.3.1 响应小照片单击动作

    在3.2.3的代码里提供了显示小图列表的eg.showThumb()方法。在单击小图片时要显示大图片。这须要调用eg.showBig()方法,仅仅有在单击小图片的时候响应单击事件才行,所以须要用eg.addListener()方法来实现,详细代码见【范例3-4】。

    【范例3-4 响应小照片单击动作】

    1.eg.showThumb = function(group){
    2.var ul = eg.$("smallPhotosList");
    3.ul.innerHTML = ''; //每次显示时要清空旧的内容
    4. var start = (group-1)*eg.groupSize; //计算须要的data数据的開始位置
    5. var end = group*eg.groupSize //计算须要的data数据的结束位置
    6. for(vari=start;(i<end&&i<eg.data.length);i++){
    7. var li = document.createElement("li");
    8. li.innerHTML = '<imgsrc="'+eg.data[i][1]+'" id="thumb'+i+'"width="80" height="40"/>';
    9. (function(i){
    10. eg.addListener(li,"click",function(){ //添加click事件监听
    11. eg.showNumber = i; //记录选中的图标序号 供其它函数调用
    12. eg.showBig();
    13. });
    14. })(i); //将i作为值传递进去
    15. ul.appendChild(li);
    16. }
    17. };
    18. eg.showBig = function(){ //依据某个编号显示大图
    19. eg.$("bigPhotoSrc").src =eg.$("thumb"+eg.showNumber).src.replace("thumb","photo")
    20. }; 
    【范例3-4】中第9行就是响应小照片单击动作的代码,这里使用了一个闭包。即一个自调用的匿名函数。

    (function(){})()是最简单的闭包。

    大括号的内容会顺序运行。假设去掉第9行和第14行代码,那么会发现始终显示当前组照片中的最后1张。在for语句体里一般要用闭包把变量值传到内部的绑定事件里。

    最具士兵袭击实战类型的JavaScript




  • 相关阅读:
    如何得到运行程序的路径,以及如何得到路径的文件夹,文件名,以及类型等等信息
    STL的心得(4)运用(MFC)
    STL的心得(3)---运用(控制台)
    【Css】清除浮动,独占一行
    [Html]加链接提示
    【JS】清除子节点
    【CSS】使Div在父元素中水平居中
    [JS]回前页
    【JS】鼠标移动到链接上变手型
    【jQuery】改变控件的使能状态
  • 原文地址:https://www.cnblogs.com/yangykaifa/p/7224723.html
Copyright © 2011-2022 走看看