JS實現(xiàn)的簡單拖拽購物車功能示例【附源碼下載】
本文實例講述了JS實現(xiàn)的簡單拖拽購物車功能。分享給大家供大家參考,具體如下:
<html>
<head>
<meta charset="utf-8" />
<title>使用拖放API將商品拖入購物車</title>
<style>
body {
font-size:12px
}
.liT{
border-bottom:solid 1px #ccc;
background-color:#eee;
font-weight:bold
}
.liF{
float:left;
margin-right:5px;
}
ul{
list-style-type:none;
padding:0px;
height:106px;
width:330px
}
ul li{
height:23px
}
ul li img{
width:68px;
height:96px;
border:solid 1px #ccc;
padding:3px
}
ul li span{
float:left;
width:70px;
padding:5px;
}
</style>
<script type="text/javascript">
function $$(id) {
return document.getElementById(id);
}
//自定義頁面加載時調(diào)用的函數(shù)
function pageload() {
//獲取全部的圖書商品
var Drag = document.getElementsByTagName("img");
//遍歷每一個圖書商品
for (var intI = 0; intI < Drag.length; intI++) {
//為每一個商品添加被拖放元素的dragstart事件
Drag[intI].addEventListener("dragstart",
function(e) {
var objDtf = e.dataTransfer;
objDtf.setData("text/html", addCart(this.title, this.alt, 1));
},
true);
}
var Cart = $$("ulCart");
//添加目標元素的drop事件
Cart.addEventListener("drop",
function(e) {
var objDtf = e.dataTransfer;
var strHTML = objDtf.getData("text/html");
var num=top_();
Cart.innerHTML += strHTML;
document.getElementById("num").innerHTML=num;
var price =document.getElementById("price").innerHTML;
document.getElementById("sum").innerHTML=num*price;
e.preventDefault();
e.stopPropagation();
},
false);
}
//添加頁面的dragover事件
document.ondragover = function(e) {
//阻止默認方法,取消拒絕被拖放
e.preventDefault();
}
//添加頁面drop事件
document.ondrop = function(e) {
//阻止默認方法,取消拒絕被拖放
e.preventDefault();
}
//自定義向購物車中添加記錄的函數(shù)
function addCart(a, b, c) {
var strHTML = "<li class='liC'>";
strHTML += "<span>" + a + "</span>";
strHTML += "<span id=\"price\">" + b + "</span>";
strHTML += "<span id=\"num\">" + c + "</span>";
strHTML += "<span id=\"sum\">" + b * c + "</span>";
strHTML += "</li>";
return strHTML;
}
//提示輸入框
function top_(){
var str=prompt("請輸入要購買的數(shù)量",1);
return str;
}
</script>
</head>
<body onLoad="pageload();">
<ul>
<li class="liF">
<img src="images/img02.jpg" id="img02"
alt="42" title="2006作品" draggable="true">
</li>
<li class="liF">
<img src="images/img03.jpg" id="img03"
alt="56" title="2008作品" draggable="true">
</li>
<li class="liF">
<img src="images/2.jpg" id="img04"
alt="52" title="2010作品" draggable="true">
</li>
<li class="liF">
<img src="images/1.jpg" id="img05"
alt="59" title="2011作品" draggable="true">
</li>
</ul>
<ul id="ulCart">
<li class="liT">
<span>書名</span>
<span>定價</span>
<span>數(shù)量</span>
<span>總價</span>
</li>
</ul>
</body>
</html>
運行效果:


附:完整實例代碼點擊此處本站下載。
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調(diào)試技巧總結(jié)》及《JavaScript數(shù)學運算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計有所幫助。
- JS實現(xiàn)基于拖拽改變物體大小的方法
- AngularJS實現(xiàn)的簡單拖拽功能示例
- 使用javaScript實現(xiàn)鼠標拖拽事件
- js實現(xiàn)QQ面板拖拽效果(慕課網(wǎng)DOM事件探秘)(全)
- js實現(xiàn)鼠標拖拽多選功能示例
- js實現(xiàn)拖拽上傳圖片功能
- 完美實現(xiàn)js拖拽效果 return false用法詳解
- 簡單實現(xiàn)js拖拽效果
- 基于AngularJS的拖拽文件上傳的實例代碼
- Java實現(xiàn)拖拽文件上傳dropzone.js的簡單使用示例代碼
- JS實現(xiàn)簡單拖拽效果
- JS實現(xiàn)簡易的圖片拖拽排序?qū)嵗a
- js實現(xiàn)控制文件拖拽并獲取拖拽內(nèi)容功能
相關(guān)文章
每天一篇javascript學習小結(jié)(Function對象)
這篇文章主要介紹了javascript中的Function對象知識點,對Function對象的基本使用方法,以及各種方法進行整理,感興趣的小伙伴們可以參考一下2015-11-11
JavaScript性能優(yōu)化總結(jié)之加載與執(zhí)行
本文詳細介紹了如何正確的加載和執(zhí)行JavaScript代碼,從而提高其在瀏覽器中的性能。對JavaScript學習者很有幫助,有需要的可以參考學習。2016-08-08
javascript 多種搜索引擎集成的頁面實現(xiàn)代碼
這個頁面是為了方便自己同時使用多種搜索引擎(呵呵我用其作默認主頁),在IE5/IE6/FireFox下均運行正常,效果如下圖2010-01-01
JS 使用for循環(huán)遍歷子節(jié)點查找元素
這篇文章主要介紹了JS 使用for循環(huán)配合數(shù)組遍歷子節(jié)點查找元素,經(jīng)測試,效果不錯,需要的朋友可以看看2014-09-09
簡單實用的HTML到UBB轉(zhuǎn)換腳本工具實現(xiàn)說明
你也許是位樂于分享的技術(shù)人員,盡管你算不上什么技術(shù)高手,但是你都希望把自己所知道的通過博客與網(wǎng)友分享。為了讓更多人知道你的經(jīng)驗,你可能會努力把博文發(fā)布到專業(yè)論壇。2009-11-11
使用Axios函數(shù)庫進行網(wǎng)絡(luò)請求的操作指南
在現(xiàn)代的前端開發(fā)中,API調(diào)用是實現(xiàn)前后端數(shù)據(jù)交互的重要環(huán)節(jié),而在眾多的HTTP庫中,Axios以其簡潔的語法、豐富的功能和易于擴展的特性,成為了開發(fā)者的首選,本篇文章將深入介紹Axios的使用方法,2024-11-11

