jquery利用拖拽方式在图片上添加热链接


Posted in Javascript onNovember 24, 2015

本文实例讲述了jquery利用拖拽方式在图片上添加热链接的实现过程,分享给大家供大家参考。具体如下:
运行效果截图如下:

jquery利用拖拽方式在图片上添加热链接

项目的需求,要在一张图片上加不同的链接,比如说,图片是一个套房,里面有沙发,茶几,酒柜,电视柜等,然后在这些物件上加一个超链接,点击后打开相关产品的介绍。

用jquery写了一个在图片添加锚点的功能,实现的原理:一个文本框写入标题,一个文本框写链接,一个添加按钮,一个编辑按钮,当写好内容后点击添中添加,便会在图片的上方出现一个P标签,然后按着鼠标左键拖拽该标签放到相应的地方松开就可以了,下面来看具体代码。

首入引入jquery库

<script src="js/jquery/1.11.1/jquery.min.js"></script>

构建html。

<div class="box">
 <input type="text" name="title">
 <input type="text" name="link" value="http://">
  <input type="button" value="添加链接" id="add">
 <input type="button" value="编辑" id="show">
</div>
<div class="img_box">
 <img src="images/55cc64813c330.jpg">
</div>

写上CSS,注意这里标签的位置是相对于图片的位置的,所以图片的img_box要加上position: relative;

*{padding: 0; margin: 0;}
.box{margin: 10px;}
.img_box{position: relative;}
.img_box .maodian{position: absolute; padding: 5px 10px; border-right: 5px; background: #000; 
   filter:alpha(opacity=40); 
   -moz-opacity:0.4; 
   opacity:0.4;
   top:10px;
   left:10px;
   color:#FFF;
   font-size: 12px;
   font-family: "宋体";
   cursor: pointer;
}
.maodian a{color: #FFF; text-decoration: none;}

写上JS

$(function(){
   var obj = null ;//定义标签对象的全局变量,目的用于编辑
   $("#add").click(function(){//绑定添加按钮单击事件
    var title = $("input[name=title]").val();//取得标题内容
    var link = $("input[name=link]").val();//取得超链接
    var html = "<p class='maodian'><a href='"+link+"'>"+title+"</a></p>";组装P标签
    $(".img_box").append(html); //添加到img_box div中,即图片的后面
   });
 
   $(".img_box").delegate(".maodian","mousedown",function(e){//绑定标签鼠标按下事件
    obj = $(this);//把当前标签对象赋值给变量
    if(obj.setCapture){ //用于兼容非准浏览器
     obj.setCapture();
    }
    $("input[name=title]").val(obj.find("a").text());//把点中标签的内容加到标题文本框中
    $("input[name=link]").val(obj.find("a").attr("href"));/把点中标签的链接加到链接本框中
     var _x = e.pageX - obj.offset().left;//取得鼠标到标签左边left的距离
     var _y = e.pageY - obj.offset().top; //取得鼠标到标签顶部top的距离
     var oWidth = $(this).outerWidth(); //取得标签的宽,包括padding
     var oHeight = $(this).outerHeight();//取得标签的高,包括padding
     var x=0,y=0; 定义移动的全局变量
 
     $(".img_box").bind("mousemove",function(e){
      var img_position = $(".img_box").offset(); //取得图片的位置
      x = e.pageX -_x - img_position.left; //计算出移动的x值
      y = e.pageY -_y - img_position.top; //计算出移动的y值
      if(x<0){ //如果移动小于0,证明移到了图片外,应设为0
       x = 0;
      }else if(x>($(".img_box img").width()-oWidth)){
      //如果移动大于图片的宽度减去标签的宽度,证明移到了图片外,应该设为可用的最大值
       x = $(".img_box img").width()-oWidth;
      }
 
      if(y<0){ //同上
       y = 0;
      }else if(y>($(".img_box img").height()-oHeight)){
       y = $(".img_box img").height()-oHeight;
      }
      obj.css({"left":x,"top":y});
     });
 
     $(".img_box").bind("mouseup",function(){ //绑定鼠标左键弹起事件
      $('.img_box').unbind("mousemove"); //移动mousemove事件
      $(this).unbind("mouseup"); //移动mouseup事件
      if(obj.releaseCapture){ //兼容非标准浏览器
      obj.releaseCapture();
     }
      
     });
     return false; //用于选中文字时取消浏览器的默认事件
   });
 
   $(".img_box").delegate(".maodian","dblclick",function(){//绑定双击事件
    $(this).remove(); //删除当前标签
   })
 
   $("#show").click(function(){//绑定编辑按钮
     //更新内容到标签
    obj.find("a").text($("input[name=title]").val()).attr("href",link);
   })
  
   $(".img_box").delegate("a","click",function(){ //取消a标签的单击默认事件
    return false;
   })
 
  })

以上就是本文的全部内容,希望对大家的学习有所帮助。

Javascript 相关文章推荐
SWFObject 2.1以上版本语法介绍
Jul 10 Javascript
Javascript表达式中连续的 &amp;&amp; 和 || 之赋值区别
Oct 17 Javascript
js 完美图片新闻轮转效果,腾讯大粤网首页图片轮转改造而来
Nov 21 Javascript
jquery实现效果比较好的table选中行颜色
Mar 25 Javascript
express的中间件bodyParser详解
Dec 04 Javascript
javascript实现根据身份证号读取相关信息
Dec 17 Javascript
javascript中substring()、substr()、slice()的区别
Aug 30 Javascript
用JavaScript获取页面文档内容的实现代码
Jun 10 Javascript
完美解决input[type=number]无法显示非数字字符的问题
Feb 28 Javascript
如何理解jQuery中的ajaxSubmit方法
Mar 13 Javascript
requirejs按需加载angularjs文件实例
Jun 08 Javascript
JavaScript实现的DOM绘制柱状图效果示例
Aug 08 Javascript
jquery中checkbox使用方法简单实例演示
Nov 24 #Javascript
基于Jquery和CSS3制作数字时钟附源码下载(CSS3篇)
Nov 24 #Javascript
基于jQuery和CSS3制作数字时钟附源码下载(jquery篇)
Nov 24 #Javascript
基于jquery实现简单的手风琴特效
Nov 24 #Javascript
jQuery插件实现无缝滚动特效
Nov 24 #Javascript
Jquery ajax加载等待执行结束再继续执行下面代码操作
Nov 24 #Javascript
谈谈encodeURI和encodeURIComponent以及escape的区别与应用
Nov 24 #Javascript
You might like
PHP zip扩展Linux下安装过程分享
2014/05/05 PHP
destoon找回管理员密码的方法
2014/06/21 PHP
高质量PHP代码的50个实用技巧必备(上)
2016/01/22 PHP
YII2框架使用控制台命令的方法分析
2020/03/18 PHP
用javascript实现分割提取页面所需内容
2007/05/09 Javascript
js 获取和设置css3 属性值的实现方法
2013/05/06 Javascript
解析js中获得父窗口链接getParent方法以及各种打开窗口的方法
2013/06/19 Javascript
Jquery实现显示和隐藏的4种简单方式
2013/08/28 Javascript
jquery如何判断某元素是否具备指定的样式
2013/11/05 Javascript
Javascript单例模式的介绍和实例
2016/10/08 Javascript
Javascript 判断两个IP是否在同一网段实例代码
2016/11/28 Javascript
JS中正则表达式全局匹配模式 /g用法详解
2017/04/01 Javascript
使用JS实现导航切换时高亮显示的示例讲解
2018/08/22 Javascript
微信小程序 (地址选择1)--选取搜索地点并显示效果
2019/12/17 Javascript
微信小程序实现简单文字跑马灯
2020/05/26 Javascript
vue动态加载SVG文件并修改节点数据的操作代码
2020/08/17 Javascript
python中enumerate的用法实例解析
2014/08/18 Python
浅谈python配置与使用OpenCV踩的一些坑
2018/04/02 Python
tensorflow 输出权重到csv或txt的实例
2018/06/14 Python
利用Python将每日一句定时推送至微信的实现方法
2018/08/13 Python
Tensorflow的常用矩阵生成方式
2020/01/04 Python
pytorch程序异常后删除占用的显存操作
2020/01/13 Python
Python趣味实例,实现一个简单的抽奖刮刮卡
2020/07/18 Python
基于python调用jenkins-cli实现快速发布
2020/08/14 Python
详解Python中import机制
2020/09/11 Python
全球性的众包图形设计市场:DesignCrowd
2021/02/02 全球购物
应届毕业生求职自荐书
2014/01/03 职场文书
个人担保书范文
2014/05/20 职场文书
学校志愿者活动总结
2014/06/27 职场文书
就业协议书样本
2014/08/20 职场文书
感恩老师演讲稿600字
2014/08/28 职场文书
2014年专项整治工作总结
2014/11/17 职场文书
2015年敬老月活动总结
2015/03/27 职场文书
小学思想品德教学反思
2016/02/24 职场文书
Go Gin实现文件上传下载的示例代码
2021/04/02 Golang
Redis实现主从复制方式(Master&Slave)
2022/06/21 Redis