Home >Web Front-end >JS Tutorial >Avalonjs implements simple shopping cart function

Avalonjs implements simple shopping cart function

不言
不言Original
2018-05-05 16:08:041559browse

This article mainly introduces Avalonjs to implement a simple shopping cart function, which has certain reference value. Now I share it with you. Friends in need can refer to it

avalon is the most powerful MVVM framework in China Recently, in the editor's shopping cart project, we used avalon to implement some modules, so it was natural to use avalon to implement the shopping cart. Next, through this article, I will share with you the example code of Avalonjs to implement a simple shopping cart function. Friends who need it can refer to it

. First, I will briefly introduce the concept of avalon

avalon is one of the most powerful MVVM frameworks in China. Although the Taobao KISSY team also developed two MVVM frameworks, they all came to nothing. There are few other MVVM frameworks. Only foreigners and idle architects like me have time to study this stuff. I predicted a long time ago that MVVM is the ultimate front-end solution. I have a deep understanding of Shanda Pass when I worked for Shanda Wireless. One business logic corresponds to more than ten different interfaces, and a layered architecture is essential. Therefore, two-way binding serves as an antidote, combined with the long-popular MVC framework, to derive the artifact of MVVM.

Because we have been working on a shopping cart recently, and we use avalon to implement some modules, so we naturally use avalon to implement the shopping cart. Currently, we find that avalon is relatively powerful, which greatly saves code. quantity.

The general functions of a shopping cart are to add and subtract quantities, select products, delete products and calculate amounts. Because avalon has a two-way binding function, it eliminates dom operations and only needs to complete the logic of the function. This can be achieved in the following steps.

1. Html structure of the page

The good effect is not considered here, so it is implemented directly with the simplest HTML, which mainly includes controllers and list loops. Amount display, the simple code structure is as follows

<body ms-controller="test">
 <ul ms-visible="arr.length">
  <li><input type="checkbox"
 ms-click="checkAll" ms-duplex-checked="checkAllbool"/>全选</li>
  <li ms-repeat="arr"
 >
  <input type="checkbox"
 ms-attr-value="el.id" ms-duplex="selected" />
  {{el.text}}
  <input type="text"
 name="" ms-attr-value="el.num" ms-on-input="changeNum(el)">
  <a href="javascript:;" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" 
 ms-click="plus(el)">加</a>
  <a href="javascript:;" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" 
 ms-click="minus(el)">减</a>
  <a href="javascript:;" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" 
 ms-click="del(el)">删除</a>
  <p>单价:{{el.price
 | currency}}</p>
  <p>金额:{{el.num*el.price
 | currency}}</p>
  </li>
 </ul>
 <p>总金额:{{total
 | currency}}</p>
 </body>

There are several functional events such as all selection, addition, subtraction, and deletion. The amount uses the filter currency.

2. Introduce avalon.js and define the model

It is necessary to introduce js, then you can define it after introducing avalon.js

var vm
 = avalon.define({
  $id:
"test"
});

This way A simple model is defined. The $id passed in is the value of the controller. The controller in the example of this article is written in the body. If you don’t understand, you can check the official website.

3. Define the products in the shopping cart

In the actual project, this must be obtained through the background. Here it is directly defined for demonstration purposes, starting from the first You can see from the html structure of the click that the items in the shopping cart here use arr, so the next thing to define is arr, which can be defined like this

arr
 : [
 {
 id:1,
 num:1,
 price:45.5,
 text:&#39;商品1&#39;
 },
 {
 id:2,
 num:1,
 price:8.8,
 text:&#39;商品2&#39;
 }<span
 style="font-size:
 9pt; line-height: 1.5;">]</span>

Here we define two for testing, and then we need a value. Save the selected product id. Here, add a selected attribute to the model, the type is array

selected:[]

4. Define the model and method of selecting all

Generally, there is a function of selecting all in the shopping cart, but the form of expression is different, so it can be defined like this

checkAllbool
 : false,
checkAll
 : function()
 {
 if (this.checked)
 {
  var _arr
 = [];
  avalon.each(vm.arr,function(index,item){
   _arr[index]
 = item.id+&#39;&#39;;
  });
  vm.selected
 = _arr;
 }
else {
  vm.selected=[];
 }
}

Through the checkAllbool attribute, it is implemented and judged whether "select all" is selected, and through checkAll To select all or unselect all, it is actually to modify the selected attribute in the model. If selected is an empty array, no one is selected. If that needs to be selected, just put the corresponding value into the selected array, because in The checkbox in HTML is bound using ms-duplex, and the bound attribute is the selected attribute.

4. Methods of defining addition, subtraction, and deletion

Addition and subtraction are mainly changes in quantity, while deletion requires that the product be directly removed from arr (previously) Delete

plus:
function(el){
 el.num++;
 vm.cal();
 },
minus:
function(el){
 if(el.num>1){
 el.num--;
 vm.cal();
 }
},
del:
function(el){
 vm.arr.remove(el);
},
changeNum:
function(el){
 var _value
 = this.value,
 _reg
 = /^[1-9]\d?$/
 ;
 if(!_reg.test(_value)){
 this.value
 = 1;
 el.num
 = 1;
 }else{
 el.num
 = _value;
 }
 vm.cal();
}

from the defined attributes) There is another method that is executed when the input box changes. Here, the operation is performed by entering and exiting the object. You can look at the html code in the first step and you will understand. Whether it is changes, additions or subtractions, vm.cal must be executed in the end. vm.cal calculates the total amount, which will be explained below.

The methods of addition and subtraction are very simple, just modify the num attribute. changeNum adds a regular judgment to determine whether the input is a number.

5. Define the calculation of the total amount

The method of calculating the total amount is very simple, that is, multiply the quantity of all selected products by the unit price and add them up, but here Another method is involved, which is to find the corresponding product through the product ID, so that the amount of the product can be calculated.

total:0,
cal:
function(){
 var _arr
 = this.arr,
 _selected
 = this.selected,
 i
 = 0,
 _obj
 = &#39;&#39;,
 _prcie
 = 0
 ;
 if(_selected.length){
 for(;i<_selected.length;i++){
  _obj
 = this.findById(_selected[i])
 ||{};
  if(_obj.price
 && _obj.num){
   _prcie
 = _prcie + _obj.price * _obj.num;
  }
 }
 }
 this.total
 = _prcie;
 },
findById:
function(id){
 if(!id)
return &#39;&#39;;
 var i=0,
  _arr
 = this.arr,
  _obj
 = &#39;&#39;,
  _id
 = parseInt(id,10)
 ;
  for(;i<_arr.length;i++){
  if(_arr[i].id
 === _id){
   _obj
 = _arr[i];
  }
 }
  return _obj;
}

The main thing used here is a loop. Find the object of the product and then calculate the amount of the product and add it up. The code is slightly longer.

6. Monitoring attributes

    需要监听两个属性,那就是 selected 和 arr,监听 selected是为了随时了解商品有没有全选中,主要通过监听Length。监听arr是判断商品有没有被删除,如果arr的length改变,则表示商品有被删除,需要重新计算总金额。

vm.selected.$watch("length",
function(n)
 {
 vm.checkAllbool
 = n === vm.arr.size()
 vm.cal();
});
vm.arr.$watch("length",
function(n)
 {
 vm.cal();
});

    通过上面的步骤分析,可以了解了大概的实现流程,下面是完整的代码。

 
 
 购物车
 
  
 
 <script>
  var
 vm = avalon.define({
  $id:
 "test",
  arr
 : [
   {
   id:1,
   num:1,
   price:45.5,
   text:&#39;商品1&#39;
   },
   {
   id:2,
   num:1,
   price:8.8,
   text:&#39;商品2&#39;
   }
  ],
  selected
 : ["1"],
  checkAllbool
 : false,
  checkAll
 : function() {
   if
 (this.checked) {
   var
 _arr = [];
   avalon.each(vm.arr,function(index,item){
    _arr[index]
 = item.id+&#39;&#39;;
   });
   vm.selected
 = _arr;
   }
 else {
   vm.selected=[];
   }
  },
  plus:
 function(el){
   el.num++;
   vm.cal();
  },
  minus:
 function(el){
   if(el.num>1){
   el.num--;
   vm.cal();
   }
  },
  del:
 function(el){
   vm.arr.remove(el);
  },
  changeNum:
 function(el){
   var
 _value = this.value,
   _reg
 = /^[1-9]\d?$/
   ;
   if(!_reg.test(_value)){
   this.value
 = 1;
   el.num
 = 1;
   }else{
   el.num
 = _value;
   }
   vm.cal();
  },
  total:0,
  cal:
 function(){
   var
 _arr = this.arr,
   _selected
 = this.selected,
   i
 = 0,
   _obj
 = &#39;&#39;,
   _prcie
 = 0
   ;
   if(_selected.length){
   for(;i<_selected.length;i++){
    _obj
 = this.findById(_selected[i]) ||{};
    if(_obj.price
 && _obj.num){
    _prcie
 = _prcie + _obj.price * _obj.num;
    }
   }
   }
   this.total
 = _prcie;
   },
  findById:
 function(id){
   if(!id)
 return &#39;&#39;;
   var
 i=0,
   _arr
 = this.arr,
   _obj
 = &#39;&#39;,
   _id
 = parseInt(id,10)
   ;
   for(;i<_arr.length;i++){
   if(_arr[i].id
 === _id){
    _obj
 = _arr[i];
   }
   }
   return
 _obj;
  }
  });
  vm.selected.$watch("length",
 function(n) {
  vm.checkAllbool
 = n === vm.arr.size()
  vm.cal();
  });
  vm.arr.$watch("length",
 function(n) {
  vm.cal();
  });
  vm.cal();
 </script>
 
 <body ms-controller="test">
 <ul ms-visible="arr.length">
  <li><input type="checkbox"
 ms-click="checkAll" ms-duplex-checked="checkAllbool"/>全选</li>
  <li ms-repeat="arr"
 >
  <input type="checkbox"
 ms-attr-value="el.id" ms-duplex="selected" />
  {{el.text}}
  <input type="text"
 name="" ms-attr-value="el.num" ms-on-input="changeNum(el)">
  <a href="javascript:;" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" 
 ms-click="plus(el)">加</a>
  <a href="javascript:;" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" 
 ms-click="minus(el)">减</a>
  <a href="javascript:;" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" 
 ms-click="del(el)">删除</a>
  <p>单价:{{el.price
 | currency}}</p>
  <p>金额:{{el.num*el.price
 | currency}}</p>
  </li>
 </ul>
 <p>总金额:{{total
 | currency}}</p>
 </body>

    用avalon时间还不久,一步步来,希望能更深入了解mvvm框架,在后面的日子里应用更多的场景。


The above is the detailed content of Avalonjs implements simple shopping cart function. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn