jquery利用拖拽方式在图片上添加热链接_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="/static/imghw/default1.png" data-src="images/55cc64813c330.jpg" class="lazy" alt="jquery利用拖拽方式在图片上添加热链接_jquery" > </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; }) })
以上就是本文的全部内容,希望对大家的学习有所帮助。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

不同JavaScript引擎在解析和执行JavaScript代码时,效果会有所不同,因为每个引擎的实现原理和优化策略各有差异。1.词法分析:将源码转换为词法单元。2.语法分析:生成抽象语法树。3.优化和编译:通过JIT编译器生成机器码。4.执行:运行机器码。V8引擎通过即时编译和隐藏类优化,SpiderMonkey使用类型推断系统,导致在相同代码上的性能表现不同。

Python更适合初学者,学习曲线平缓,语法简洁;JavaScript适合前端开发,学习曲线较陡,语法灵活。1.Python语法直观,适用于数据科学和后端开发。2.JavaScript灵活,广泛用于前端和服务器端编程。

从C/C 转向JavaScript需要适应动态类型、垃圾回收和异步编程等特点。1)C/C 是静态类型语言,需手动管理内存,而JavaScript是动态类型,垃圾回收自动处理。2)C/C 需编译成机器码,JavaScript则为解释型语言。3)JavaScript引入闭包、原型链和Promise等概念,增强了灵活性和异步编程能力。

JavaScript在Web开发中的主要用途包括客户端交互、表单验证和异步通信。1)通过DOM操作实现动态内容更新和用户交互;2)在用户提交数据前进行客户端验证,提高用户体验;3)通过AJAX技术实现与服务器的无刷新通信。

JavaScript在现实世界中的应用包括前端和后端开发。1)通过构建TODO列表应用展示前端应用,涉及DOM操作和事件处理。2)通过Node.js和Express构建RESTfulAPI展示后端应用。

理解JavaScript引擎内部工作原理对开发者重要,因为它能帮助编写更高效的代码并理解性能瓶颈和优化策略。1)引擎的工作流程包括解析、编译和执行三个阶段;2)执行过程中,引擎会进行动态优化,如内联缓存和隐藏类;3)最佳实践包括避免全局变量、优化循环、使用const和let,以及避免过度使用闭包。

Python和JavaScript在社区、库和资源方面的对比各有优劣。1)Python社区友好,适合初学者,但前端开发资源不如JavaScript丰富。2)Python在数据科学和机器学习库方面强大,JavaScript则在前端开发库和框架上更胜一筹。3)两者的学习资源都丰富,但Python适合从官方文档开始,JavaScript则以MDNWebDocs为佳。选择应基于项目需求和个人兴趣。

Python和JavaScript在开发环境上的选择都很重要。1)Python的开发环境包括PyCharm、JupyterNotebook和Anaconda,适合数据科学和快速原型开发。2)JavaScript的开发环境包括Node.js、VSCode和Webpack,适用于前端和后端开发。根据项目需求选择合适的工具可以提高开发效率和项目成功率。
