這篇文章給大家分享的是有關(guān)如何使用HTML5實(shí)現(xiàn)拖拽功能的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。
創(chuàng)新互聯(lián)建站專(zhuān)注于網(wǎng)站建設(shè),為客戶(hù)提供成都做網(wǎng)站、網(wǎng)站設(shè)計(jì)、網(wǎng)頁(yè)設(shè)計(jì)開(kāi)發(fā)服務(wù),多年建網(wǎng)站服務(wù)經(jīng)驗(yàn),各類(lèi)網(wǎng)站都可以開(kāi)發(fā),成都品牌網(wǎng)站建設(shè),公司官網(wǎng),公司展示網(wǎng)站,網(wǎng)站設(shè)計(jì),建網(wǎng)站費(fèi)用,建網(wǎng)站多少錢(qián),價(jià)格優(yōu)惠,收費(fèi)合理。
問(wèn)題:突然奇想,想在電影網(wǎng)上加一個(gè)收藏(類(lèi)似于購(gòu)物車(chē)的東西),可以通過(guò)拖拽圖片進(jìn)行添加
前提:需要了解HTML5中國(guó)LoaclStrorage(當(dāng)然,其他的web存儲(chǔ)也行,我用的是LocalStroage)
解決:這里主要重點(diǎn)強(qiáng)調(diào)關(guān)于進(jìn)行拖拽功能的細(xì)節(jié),具體html和css就自己慢慢弄吧
首先這里先是對(duì)收藏按鈕進(jìn)行點(diǎn)擊顯示新的p框(存放收藏的電影),二次點(diǎn)擊隱藏p框,這里不做過(guò)多介紹
為可以進(jìn)行拖拽的圖片進(jìn)行設(shè)置屬性:draggable屬性和ondragstart事件
varpic_list=document.getElementsByClassName("middle_content")[0];
varpic_list_li=pic_list.getElementsByTagName("li");
for(vari=0;i<pic_list_li.length;i++){
varimage=pic_list_li[i].getElementsByTagName("img")[0];
image.setAttribute("draggable",true);
image.ondragstart=drag;
我這里的代碼就是獲取所選要拖拽圖片的父元素,然后進(jìn)行遍歷,將每一個(gè)img都設(shè)置屬性和事件
3.分別編寫(xiě)進(jìn)行拖拽時(shí)的函數(shù)和拖拽完成的函數(shù)
//設(shè)置拖拽效果
functiondrag(e){
e=e||event;
e.dataTransfer.effectAllowed="copy";
//IE需通過(guò)服務(wù)器訪(fǎng)問(wèn)方式,F(xiàn)F、chrome支持本地方式進(jìn)行訪(fǎng)問(wèn)
e.dataTransfer.setData("text",e.target.src);//IE兼容寫(xiě)法
//e.dataTransfer.setData("text/plain",e.target.src);//標(biāo)準(zhǔn)寫(xiě)法
}
“copy”那就是字面意思,復(fù)制一份當(dāng)然的data,當(dāng)然還有其他的屬性值,這里就不做進(jìn)一步解釋
//拖拽釋放效果
functiondrop(e){
//方式拖拽事件傳播
allowDrop(e);
//從拖拽事件中獲取數(shù)據(jù)
vardata=e.dataTransfer.getData("text");
//e.target.id=="dropdown",表示目標(biāo)對(duì)象是p(dropdown)
//e.target.parentNode.id=="dropdown"表示目標(biāo)對(duì)象是dropdown的直接子元素UL
//e.target.parentNode.parentNode.id=="dropdown"表示目標(biāo)對(duì)象是UL中的LI
//e.target.parentNode.parentNode.parentNode.id=="dropdown"表示目標(biāo)對(duì)是<a>元素
//e.target.parentNode.parentNode.parentNode.parentNode.id=="dropdown"表示目標(biāo)對(duì)象是<img>元素
if(e.target.id=="dropdown"||e.target.parentNode.id=="dropdown"
||e.target.parentNode.parentNode.id=="dropdown"
||e.target.parentNode.parentNode.parentNode.id=="dropdown"
||e.target.parentNode.parentNode.parentNode
.parentNode.id=="dropdown"){
//從localStorage中嘗試根據(jù)Src讀取數(shù)據(jù)
varnewFilms=readFromStorage(data);
if(newFilms==null){
films.filmsSrc=data;
}
//把處理后的商品信息存儲(chǔ)到localStorage
localStorage.setItem(data,JSON.stringify(films));
//重新加載并刷新頁(yè)面中的collect
document.getElementsByClassName("dropdown")[0].innerHTML=loadCollect();
}
}
4.上述代碼中有關(guān)于key值讀取localstrorage的值,我將其封裝成了json對(duì)象,因?yàn)楹笃诳赡軘?shù)據(jù)會(huì)增多,比如,不僅僅是加入圖片的src,還有可能是有關(guān)圖片的介紹,例如,導(dǎo)演,演員,簡(jiǎn)介之類(lèi)的信息,這時(shí),用json對(duì)象會(huì)相對(duì)于更好一些
所有需要將讀取的localstroage值封裝成json對(duì)象
//根據(jù)key讀取localStorage的值并封裝成JSON
functionreadFromStorage(key){
varjsonStr=localStorage.getItem(key);
varnewFilms=JSON.parse(jsonStr);
returnnewFilms;
}
感謝各位的閱讀!關(guān)于“如何使用HTML5實(shí)現(xiàn)拖拽功能”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
網(wǎng)頁(yè)題目:如何使用HTML5實(shí)現(xiàn)拖拽功能
網(wǎng)站鏈接:http://jinyejixie.com/article30/johjpo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站營(yíng)銷(xiāo)、網(wǎng)站設(shè)計(jì)、軟件開(kāi)發(fā)、Google、App開(kāi)發(fā)、云服務(wù)器
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)