国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > JavaScript > 正文

jquery利用拖拽方式在圖片上添加熱鏈接

2019-11-20 11:10:30
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

本文實(shí)例講述了jquery利用拖拽方式在圖片上添加熱鏈接的實(shí)現(xiàn)過(guò)程,分享給大家供大家參考。具體如下:
運(yùn)行效果截圖如下:

項(xiàng)目的需求,要在一張圖片上加不同的鏈接,比如說(shuō),圖片是一個(gè)套房,里面有沙發(fā),茶幾,酒柜,電視柜等,然后在這些物件上加一個(gè)超鏈接,點(diǎn)擊后打開(kāi)相關(guān)產(chǎn)品的介紹。

用jquery寫(xiě)了一個(gè)在圖片添加錨點(diǎn)的功能,實(shí)現(xiàn)的原理:一個(gè)文本框?qū)懭霕?biāo)題,一個(gè)文本框?qū)戞溄樱粋€(gè)添加按鈕,一個(gè)編輯按鈕,當(dāng)寫(xiě)好內(nèi)容后點(diǎn)擊添中添加,便會(huì)在圖片的上方出現(xiàn)一個(gè)P標(biāo)簽,然后按著鼠標(biāo)左鍵拖拽該標(biāo)簽放到相應(yīng)的地方松開(kāi)就可以了,下面來(lái)看具體代碼。

首入引入jquery庫(kù)

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

構(gòu)建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>

寫(xiě)上CSS,注意這里標(biāo)簽的位置是相對(duì)于圖片的位置的,所以圖片的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;}

寫(xiě)上JS

$(function(){   var obj = null ;//定義標(biāo)簽對(duì)象的全局變量,目的用于編輯   $("#add").click(function(){//綁定添加按鈕單擊事件    var title = $("input[name=title]").val();//取得標(biāo)題內(nèi)容    var link = $("input[name=link]").val();//取得超鏈接    var html = "<p class='maodian'><a href='"+link+"'>"+title+"</a></p>";組裝P標(biāo)簽    $(".img_box").append(html); //添加到img_box div中,即圖片的后面   });    $(".img_box").delegate(".maodian","mousedown",function(e){//綁定標(biāo)簽鼠標(biāo)按下事件    obj = $(this);//把當(dāng)前標(biāo)簽對(duì)象賦值給變量    if(obj.setCapture){ //用于兼容非準(zhǔn)瀏覽器     obj.setCapture();    }    $("input[name=title]").val(obj.find("a").text());//把點(diǎn)中標(biāo)簽的內(nèi)容加到標(biāo)題文本框中    $("input[name=link]").val(obj.find("a").attr("href"));/把點(diǎn)中標(biāo)簽的鏈接加到鏈接本框中     var _x = e.pageX - obj.offset().left;//取得鼠標(biāo)到標(biāo)簽左邊left的距離     var _y = e.pageY - obj.offset().top; //取得鼠標(biāo)到標(biāo)簽頂部top的距離     var oWidth = $(this).outerWidth(); //取得標(biāo)簽的寬,包括padding     var oHeight = $(this).outerHeight();//取得標(biāo)簽的高,包括padding     var x=0,y=0; 定義移動(dòng)的全局變量      $(".img_box").bind("mousemove",function(e){      var img_position = $(".img_box").offset(); //取得圖片的位置      x = e.pageX -_x - img_position.left; //計(jì)算出移動(dòng)的x值      y = e.pageY -_y - img_position.top; //計(jì)算出移動(dòng)的y值      if(x<0){ //如果移動(dòng)小于0,證明移到了圖片外,應(yīng)設(shè)為0       x = 0;      }else if(x>($(".img_box img").width()-oWidth)){      //如果移動(dòng)大于圖片的寬度減去標(biāo)簽的寬度,證明移到了圖片外,應(yīng)該設(shè)為可用的最大值       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(){ //綁定鼠標(biāo)左鍵彈起事件      $('.img_box').unbind("mousemove"); //移動(dòng)mousemove事件      $(this).unbind("mouseup"); //移動(dòng)mouseup事件      if(obj.releaseCapture){ //兼容非標(biāo)準(zhǔn)瀏覽器      obj.releaseCapture();     }           });     return false; //用于選中文字時(shí)取消瀏覽器的默認(rèn)事件   });    $(".img_box").delegate(".maodian","dblclick",function(){//綁定雙擊事件    $(this).remove(); //刪除當(dāng)前標(biāo)簽   })    $("#show").click(function(){//綁定編輯按鈕     //更新內(nèi)容到標(biāo)簽    obj.find("a").text($("input[name=title]").val()).attr("href",link);   })     $(".img_box").delegate("a","click",function(){ //取消a標(biāo)簽的單擊默認(rèn)事件    return false;   })   })

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 双鸭山市| 泸西县| 海口市| 衡南县| 新宁县| 南川市| 临江市| 赤峰市| 融水| 隆昌县| 渑池县| 称多县| 光泽县| 隆昌县| 策勒县| 偏关县| 策勒县| 平远县| 祁东县| 青田县| 宜都市| 清远市| 郑州市| 玉屏| 毕节市| 静安区| 光山县| 奈曼旗| 永寿县| 辽宁省| 息烽县| 平塘县| 桓仁| 沿河| 基隆市| 婺源县| 黎平县| 宜兰县| 灵山县| 晋江市| 云梦县|