浅谈JavaScript_DOM学习篇_图片切换小案例


Posted in Javascript onMarch 19, 2019

今天开始学习DOM操作,下面写一个小案例来巩固下知识点.

DOM: document object model (文档对象模型)

根据id获取页面元素 : 如: var xx = document.getElementById("id");

根据标签获取元素: 如: var xx = document.getElementsByTagName("div");

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
  <style>
    * {
      margin: 0;
      padding: 0;
    }

    #outer {
      width: 500px;
      /*设置上边距50px 水平居中*/
      margin: 50px auto;
      /*设置边框*/
      padding: 10px;
      background-color: greenyellow;
      /*设置文本居中*/
      text-align: center;
    }

    img {
      width: 500px;
    }
  </style>


  <script>

 //btn 为按钮id  clickEventFunction 为点击后执行的操作函数
    function addClick(btn, clickEventFunction) {
      var myButton = document.getElementById(btn);
      myButton.onclick = clickEventFunction;
    };

    window.onload = function () {
      (function () {
        var pics = ["imgs/1.png",
          "imgs/2.png",
          "imgs/3.png"];
        var index = 0;
        showPicNum(index);
        var img = document.getElementsByTagName("img")[0];

        // var btn1 = document.getElementById("btn1");
        var btn2 = document.getElementById("btn2");
        addClick("btn1", function () {
          index--;
          if (index <= -1) {
            index = pics.length - 1;
          }
          console.log(index + " ----- ");
          img.src = pics[index];
          showPicNum(index);
        });
        addClick("btn2", function () {
          index++;
          if (index >= pics.length) {
            index = 0;
          }
          console.log(index + " ++++++++ ");
          img.src = pics[index];
          showPicNum(index);
        });

        //
        // btn1.onclick = function () {
        //   index --;
        //   if(index <= -1){
        //     index = pics.length - 1;
        //   }
        //   console.log(index + " ----- ");
        //   img.src = pics[index];
        //   showPicNum(index);
        // };
        // btn2.onclick = function () {
        //   index ++;
        //   if(index >= pics.length){
        //     index = 0;
        //   }
        //   console.log(index + " ++++++++ ");
        //   img.src = pics[index];
        //   showPicNum(index);
        // };
        console.log(index);

        /**
         * 展示当前图片为第几张
         * @param index  当前图片索引
         */
        function showPicNum(index) {
          var descrs = document.getElementById("discs");
          descrs.innerText = "一共" + pics.length + "张图片,当前第" + ++index + "张";
        }
      }())
    };
  </script>
</head>
<body>
<div id="outer">
  <p id="discs"></p>
  <img src="imgs/1.png"/><br>
  <button id="btn1" type="button" value="上一张">上一张</button>
  <button id="btn2" type="button" value="下一张">下一张</button>
</div>
</body>
</html>

文档目录:

浅谈JavaScript_DOM学习篇_图片切换小案例

效果如下:

浅谈JavaScript_DOM学习篇_图片切换小案例

以上所述是小编给大家介绍的JavaScriptDOM图片切换小案例详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
比较全的JS checkbox全选、取消全选、删除功能代码
Dec 19 Javascript
JavaScript 面向对象的之私有成员和公开成员
May 04 Javascript
jQuery队列控制方法详解queue()/dequeue()/clearQueue()
Dec 02 Javascript
关于img的href和src取变量及赋值的方法
Apr 28 Javascript
jQuery弹出框代码封装DialogHelper
Jan 30 Javascript
解决js页面滚动效果scrollTop在FireFox与Chrome浏览器间的兼容问题的方法
Dec 03 Javascript
js+css简单实现网页换肤效果
Dec 29 Javascript
jQuery使用siblings获取某元素所有同辈(兄弟姐妹)元素用法示例
Jan 30 Javascript
Bootstrap禁用响应式布局的实现方法
Mar 09 Javascript
JavaScript实现前端分页控件
Apr 19 Javascript
Vuex之理解Getters的用法实例
Apr 19 Javascript
layui的表单验证支持ajax判断用户名是否重复的实例
Sep 06 Javascript
vue多层嵌套路由实例分析
Mar 19 #Javascript
vue组件数据传递、父子组件数据获取,slot,router路由功能示例
Mar 19 #Javascript
vue项目移动端实现ip输入框问题
Mar 19 #Javascript
详解使用React.memo()来优化函数组件的性能
Mar 19 #Javascript
vue组件定义,全局、局部组件,配合模板及动态组件功能示例
Mar 19 #Javascript
express.js中间件说明详解
Mar 19 #Javascript
js array数组对象操作方法汇总
Mar 18 #Javascript
You might like
PHP中英混合字符串截取函数代码
2011/07/17 PHP
Php Ctemplate引擎开发相关内容
2012/03/03 PHP
19个超实用的PHP代码片段
2014/03/14 PHP
PHP图像处理之使用imagecolorallocate()函数设置颜色例子
2014/11/19 PHP
微信公众平台之快递查询功能用法实例
2015/04/14 PHP
Yii2前后台分离及migrate使用(七)
2016/05/04 PHP
laravel实现图片上传预览,及编辑时可更换图片,并实时变化的例子
2019/11/14 PHP
Javascript Tab 导航插件 (23个)
2009/06/11 Javascript
js利用与或运算符优先级实现if else条件判断表达式
2010/04/15 Javascript
JavaScript 拾碎[三] 使用className属性
2010/10/16 Javascript
jquery easyui combox一些实用的小方法
2013/12/25 Javascript
js如何获取object类型里的键值
2014/02/18 Javascript
JavaScript用Number方法实现string转int
2014/05/13 Javascript
JavaScript中用toString()方法返回时间为字符串
2015/06/12 Javascript
微信小程序 wx.login解密出现乱码的问题解决办法
2017/03/10 Javascript
解决AjaxFileupload 上传时会出现连接重置的问题
2017/07/07 Javascript
vue 实现LED数字时钟效果(开箱即用)
2019/12/08 Javascript
Python 学习笔记
2008/12/27 Python
使用python分析git log日志示例
2014/02/27 Python
python爬取NUS-WIDE数据库图片
2016/10/05 Python
Django使用详解:ORM 的反向查找(related_name)
2018/05/30 Python
Django实战之用户认证(用户登录与注销)
2018/07/16 Python
Python数据报表之Excel操作模块用法分析
2019/03/11 Python
python+adb+monkey实现Rom稳定性测试详解
2020/04/23 Python
PyCharm设置Ipython交互环境和宏快捷键进行数据分析图文详解
2020/04/23 Python
加拿大便宜的隐形眼镜商店:Clearly
2016/09/15 全球购物
最好的意大利皮夹克:D’Arienzo
2018/12/04 全球购物
"序列点" 是什么
2016/07/29 面试题
iostream与iostream.h的区别
2015/01/16 面试题
EJB timer的种类
2014/10/28 面试题
华为python面试题
2016/05/03 面试题
教师节促销方案
2014/03/22 职场文书
五四青年节演讲稿
2014/05/26 职场文书
表彰大会新闻稿
2015/07/17 职场文书
搞笑婚礼主持词开场白
2015/11/24 职场文书
深入理解Pytorch微调torchvision模型
2021/11/11 Python