この記事では、ネイティブ js + cookie でショッピング カート機能を実現する方法を主に紹介し、ショッピング カート機能を実現するために JavaScript と cookie ストレージを組み合わせた関連操作スキルをサンプルの形式で分析します。
この記事では、ネイティブ JS の例と、Cookie がショッピング カート機能を実装する方法について説明します。参考のために皆さんと共有してください。詳細は次のとおりです:
ここでは、js+cookie を使用して、単純なショッピング カート機能を実装します。
最初は、機能を示すためだけの単純な HTML 構造です。
<ul> <li><span>a0001</span><span>shdfi</span><span>¥98.00</span> <input type="button" value="加入购物车"></li> <li><span>a0002</span><span>fbvfgdb</span><span>¥698.00</span> <input type="button" value="加入购物车"></li> <li><span>a0003</span><span>dfdfi</span><span>¥988.00</span> <input type="button" value="加入购物车"></li> <li><span>a0004</span><span>sssi</span><span>¥998.00</span> <input type="button" value="加入购物车"></li> <li><span>a0005</span><span>yyu</span><span>¥98.00</span> <input type="button" value="加入购物车"></li> <li><span>a0006</span><span>sheri</span><span>¥598.00</span> <input type="button" value="加入购物车"></li> <li><span>a0007</span><span>dsfcdhdfi</span><span>¥498.00</span> <input type="button" value="加入购物车"></li> <li><span>sbnm,</span><span>¥698.00</span><input type="button" value="加 入购物车"></li> </ul> <a href="购物车查看页面.html" rel="external nofollow" >查看购物车</a>
以下のコードは、追加ボタンをクリックした際にCookieに商品情報を追加するコードです。コード内ではCookieを操作します(setとgetは呼び出しやすいようにcookieUtilオブジェクトのメソッドとしてカプセル化されています)。 。
<script> //JSON.parse //JSON.stringify onload = function () { var input = document.getElementsByTagName("input"); //判断是否存在cookie,或是第一次添加 var arr = cookieUtil.getCookie("car") ? JSON.parse(cookieUtil.getCookie("car")) : []; //遍历给每个input元素添加点击事件 for (var j = 0; j < input.length; j++) { input[j].onclick = function () { var g_id = this.parentNode.children[0].innerHTML; var g_name = this.parentNode.children[1].innerHTML; var g_price = this.parentNode.children[2].innerHTML; //遍历cookie,判断是否已经存在该商品 for (var i = 0; i < arr.length; i++) { if (arr[i].g_id == g_id) { //已经存在该商品,商品数量+1 arr[i].num++; break;//立即结束遍历 } } //如果i的值与arr长度相同,则证明遍历结束也没有进入过if条件语句, //cookie中不存在该商品,新建一个商品对象,并添加到数组中 if (i == arr.length) { var goods = { "g_id" : g_id, "g_name" : g_name, "g_price" : g_price, num : 1 } arr.push(goods); } //把更新后的数组序列化为JSON字符串,保存到cookie中 var date = new Date(); date.setDate(date.getDate() + 10); //保存十天 //保存cookie cookieUtil.setCookie("car", JSON.stringify(arr), date); } } } </script>
カプセル化された cookieUtil オブジェクトです
//cookie Util var cookieUtil = { //添加cookie setCookie: function (name, value, expires) { var cookieText = encodeURIComponent(name) + "=" + encodeURIComponent(value); if (expires && expires instanceof Date) { cookieText += "; expires=" + expires; } // if (domain) { // cookieText += "; domain=" + domain; // } document.cookie = cookieText; }, //获取cookie getCookie: function (name) { var cookieText = decodeURIComponent(document.cookie); var cookieArr = cookieText.split("; "); for (var i = 0; i < cookieArr.length; i++) { var arr = cookieArr[i].split("="); if (arr[0] == name) { return arr[1]; } } return null; }, //删除cookie unsetCookie: function (name) { document.cookie = encodeURIComponent(name) + "=; expires=" + new Date(0); } };
上記のコードは非常に分かりやすく、Cookie 内の商品情報を取り出しています。
rreee以上が皆さんのためにまとめたもので、今後皆さんのお役に立てれば幸いです。
関連記事:
BrowserRouterとreactの連携方法-ルーターサーバー
以上がjs+cookieを使ったショッピングカート機能の実装方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。