轻松实现JavaScript图片切换


Posted in Javascript onJanuary 12, 2016

本文实例为大家介绍JavaScript图片切换的实现方法,分享给大家供大家参考,具体内容如下

效果图:

轻松实现JavaScript图片切换

网页看到非常常见的一个图片切换效果:在淘宝、JD等购物时,介绍产品的图片会有多张,一般是显示一张,底下有一排小图片,鼠标放到小图片上大图片会切换.参考vivo X5M 移动4G手机 .下面记录一下实现的过程.

1. getElementById()

该方法是操作dom非常常用的一个方法,比如有一p标签,id设为pid,通过getElementById(“pid”)就可以对该元素进行操作.

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>demo</title>
  <script type="text/javascript">
    function changeText(){
      document.getElementById("pid").innerHTML
      ="It works!";
    }
  </script>
</head>
<body>
  <p id="pid" onmouseover="changeText()">Hello word!</p>
</body>
</html>

上面代码中在body中写了一个p标签,id为pid,当鼠标放到p标签上方的时候触发onmouseover事件,执行changeText()方法,将p标签内的文档改变.

2. setAttribute()和getAttribute()

getAttribute()方法用于获取某一属性的值,setAttribute()方法用于给某一属性赋值。

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>demo</title>
  <script type="text/javascript">
    function changeUrl(){
      var baiduurl=document.getElementById("aid");
      baiduurl.getAttribute("href");
      baiduurl.setAttribute("href", 
      "http://www.taobao.com");
      baiduurl.innerHTML="淘宝";
    }
  </script>
</head>
<body>
  <a href="http://www.baidu.com" id="aid" onmouseover="changeUrl()">百度首页</a>
</body>
</html>

上面代码中,body中有一个a标签,通过getElementById()获取a标签,baiduurl.getAttribute(“href”)的值为默认的href属性,通过baiduurl.setAttribute(“href”, “http://www.taobao.com“)设置以后,该属性值改变.完整代码:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>on</title>
  <style type="text/css" media="screen">
  *{
     padding: 0;
  }
  body{
     font-family: 微软雅黑;
  }
  #imgbox{
        width: 320px;
        height: 490px;
        padding: 10px;
        box-shadow: 5px;
        border: 1px solid #ccc;
        border-radius: 10px;
      }
 #phoneimg{
       padding: 10px;
       border-color: 1px solid #cccccc;
    }

  </style>


</head>
<body>
   <div id="imgbox">
    <img src="images/phone1.jpg" height="400" width="320" alt="phone" id="phoneimg">   
    <p id="decimg">phone image1</p>
   </div>

   <table>
    <tbody>
      <tr>
        <td width="50px">
          <img src="images/phone2.jpg" height="100" width="80" title="phone image2" alt="" onmouseover="changeImg(this)" ></td>
        <td width="50px">
          <img src="images/phone3.jpg" height="100" width="80" title="phone image3" alt=""onmouseover="changeImg(this)" ></td>
        <td width="50px">
          <img src="images/phone4.jpg" height="100" width="80" title="phone image4" alt=""onmouseover="changeImg(this)" ></td>
        <td width="50px">
          <img src="images/phone5.jpg" height="100" width="80" title="phone image5" alt=""onmouseover="changeImg(this)" ></td>

      </tr>
    </tbody>
   </table>

   <script type="text/javascript">
     function changeImg(whichpic){       
         var imgattr=whichpic.getAttribute("src");
         var phoneimg=document.getElementById("phoneimg");
         phoneimg.setAttribute("src",imgattr);
         var dectext=whichpic.getAttribute("title");
         document.getElementById("decimg").innerHTML=dectext;
     }
   </script>
</body>
</html>

下一步学习一下怎么实现局部放大,大家有什么好的方法吗?可以一起探讨。

Javascript 相关文章推荐
jquery $.ajax相关用法分享
Mar 16 Javascript
json字符串之间的相互转换示例代码
Aug 21 Javascript
谈谈impress.js初步理解
Sep 09 Javascript
jQuery+CSS3实现3D立方体旋转效果
Nov 10 Javascript
js调用webservice构造SOAP进行身份验证
Apr 27 Javascript
跨域请求的完美解决方法(JSONP, CORS)
Jun 12 Javascript
利用JQuery阻止事件冒泡
Dec 01 Javascript
bootstrap+jQuery实现的动态进度条功能示例
May 25 jQuery
vue 中directive功能的简单实现
Jan 05 Javascript
浅谈Webpack多页应用HMR卡住问题
Apr 24 Javascript
vue实现后台管理权限系统及顶栏三级菜单显示功能
Jun 19 Javascript
用js编写留言板
Mar 17 Javascript
jQuery动画效果图片轮播特效
Jan 12 #Javascript
jQuery动画效果实现图片无缝连续滚动
Jan 12 #Javascript
jqueryMobile使用示例分享
Jan 12 #Javascript
WordPress中鼠标悬停显示和隐藏评论及引用按钮的实现
Jan 12 #Javascript
WordPress中利用AJAX技术进行评论提交的实现示例
Jan 12 #Javascript
基于JavaScript实现div层跟随滚动条滑动
Jan 12 #Javascript
JavaScript继承模式粗探
Jan 12 #Javascript
You might like
杏林同学录(八)
2006/10/09 PHP
基于PHP array数组的教程详解
2013/06/05 PHP
php根据身份证号码计算年龄的实例代码
2014/01/18 PHP
ThinkPHP CURD方法之where方法详解
2014/06/18 PHP
php程序总是提示验证码输入有误解决方案
2015/01/07 PHP
php中如何执行linux命令详解
2018/11/06 PHP
js一组验证函数
2008/12/20 Javascript
JQuery优缺点分析说明
2011/04/10 Javascript
jQuery使用数组编写图片无缝向左滚动
2012/12/11 Javascript
JavaScript作用域链使用介绍
2013/08/29 Javascript
JavaScript移除数组元素减少长度的方法
2013/09/05 Javascript
如何通过javascript操作web控件的自定义属性
2013/11/25 Javascript
jquery地址栏链接与a标签链接匹配之特效代码总结
2015/08/24 Javascript
Vuejs第十三篇之组件——杂项
2016/09/09 Javascript
Angular1.x自定义指令实例详解
2017/03/01 Javascript
vuejs手把手教你写一个完整的购物车实例代码
2017/07/06 Javascript
react native与webview通信的示例代码
2017/09/25 Javascript
简单了解vue.js数组的常用操作
2019/06/17 Javascript
Element的el-tree控件后台数据结构的生成以及方法的抽取
2020/03/05 Javascript
vue props default Array或是Object的正确写法说明
2020/07/30 Javascript
vue实现下拉菜单树
2020/10/22 Javascript
pyqt4教程之实现windows窗口小示例分享
2014/03/07 Python
Python numpy多维数组实现原理详解
2020/03/10 Python
DHC美国官网:日本通信销售第一的化妆品品牌
2017/11/12 全球购物
机械设计毕业生自荐信
2014/02/02 职场文书
《我为你骄傲》教学反思
2014/02/20 职场文书
数控机床专业自荐信
2014/05/19 职场文书
十周年庆典策划方案
2014/06/03 职场文书
2015年大学生入党自荐书
2015/03/24 职场文书
紧急通知
2015/04/17 职场文书
2015年高三教学工作总结
2015/07/21 职场文书
安全伴我行主题班会
2015/08/13 职场文书
python 如何做一个识别率百分百的OCR
2021/05/29 Python
Python爬虫入门案例之爬取二手房源数据
2021/10/16 Python
使用Redis做预定库存缓存功能
2022/04/02 Redis
Hive HQL支持2种查询语句风格
2022/06/25 数据库