jquery利用拖拽方式在圖片上添加熱鏈接
本文實(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í)有所幫助。
- jQuery插件實(shí)現(xiàn)文件上傳功能(支持拖拽)
- 分享jQuery網(wǎng)頁(yè)元素拖拽插件
- 基于jQuery實(shí)現(xiàn)拖拽圖標(biāo)到回收站并刪除功能
- JQuery Dialog(JS 模態(tài)窗口,可拖拽的DIV)
- JQuery UI的拖拽功能實(shí)現(xiàn)方法小結(jié)
- 簡(jiǎn)單的jquery拖拽排序效果實(shí)現(xiàn)代碼
- jQuery拖拽div實(shí)現(xiàn)思路
- JQuery之拖拽插件實(shí)現(xiàn)代碼
- 如何使用jQuery Draggable和Droppable實(shí)現(xiàn)拖拽功能
- jquery+CSS3實(shí)現(xiàn)3D拖拽相冊(cè)效果
相關(guān)文章
jquery判斷RadioButtonList和RadioButton中是否有選中項(xiàng)示例
用jquery判斷RadioButtonList和RadioButton中是否有選中項(xiàng),下面有個(gè)不錯(cuò)的示例,感興趣的朋友可以參考下2013-09-09
基于jQuery實(shí)現(xiàn)的文字按鈕表單特效整理
這里給大家整理了10個(gè)熱門(mén)的基于jQuery實(shí)現(xiàn)的文字、按鈕、表單等特效的代碼,集合起來(lái)方便大家對(duì)比使用2014-12-12
jquery 為a標(biāo)簽綁定click事件示例代碼
jquery 為a標(biāo)簽綁定click事件,當(dāng)被點(diǎn)擊時(shí)執(zhí)行一些動(dòng)作,示例代碼如下,需要的朋友可以參考參考2014-06-06
Struts2的s:radio標(biāo)簽使用及用jquery添加change事件
用到Struts2的s:radio標(biāo)簽時(shí)想給它添加一個(gè)change事件,由于此標(biāo)簽為頁(yè)面自動(dòng)生成一個(gè)radio組,不可以像正常那樣控制,于是想到用jquery來(lái)實(shí)現(xiàn)2013-04-04
jQuery結(jié)合AJAX之在頁(yè)面滾動(dòng)時(shí)從服務(wù)器加載數(shù)據(jù)
這篇文章主要介紹了jQuery結(jié)合AJAX之在頁(yè)面滾動(dòng)時(shí)從服務(wù)器加載數(shù)據(jù),文中示例服務(wù)器端為C#程序,需要的朋友可以參考下2015-06-06
jQuery插件HighCharts繪制的基本折線(xiàn)圖效果示例【附demo源碼下載】
這篇文章主要介紹了jQuery插件HighCharts繪制的基本折線(xiàn)圖效果,結(jié)合實(shí)例形式分析了jQuery基于HighCharts插件繪制圖形的具體實(shí)現(xiàn)步驟與相關(guān)操作技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2017-03-03
jQuery EasyUI ProgressBar進(jìn)度條組件
這篇文章主要為大家詳細(xì)介紹了jQuery EasyUI ProgressBar進(jìn)度條組件的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02
jQuery中DOM樹(shù)操作之使用反向插入方法實(shí)例分析
這篇文章主要介紹了jQuery中DOM樹(shù)操作之使用反向插入方法,實(shí)例分析了反向插入方法與插入方法回調(diào)的使用技巧,需要的朋友可以參考下2015-01-01

