#
whycq
2022-06-22 ba9aaf9d45bcc2ab30aefa862fe520e4ee13becc
pages/basics/pakin.vue
@@ -38,8 +38,10 @@
            <view class="square-title">
               <view class="title-sign"><view class="sign"></view></view>
               <view class="title-text"><text>商品列表</text></view>
               <!-- <label v-show="matList.length != 0" style="float: right;margin-right: 20px;margin-top: 13px;"><uni-icons type="trash" size="25" color="#a5a5a5" @click="remove()"></uni-icons></label> -->
            </view>
         </view>
         <view class="square-none"  v-show="matList.length === 0">
            <view class="v-show">暂无更多数据...</view>
         </view>
@@ -47,6 +49,9 @@
         <checkbox-group @change="checkbox">
            <view v-for="(item,index) in matList" :key="index" class="data-list bg-false" :class="'bg-'+item.checked" >
               <view class="data-list-left">
                  <!-- <view>
                     <checkbox :value="item.id+''" :checked="item.checked" style="display: block;" />
                  </view> -->
                  <view class="matnr"><text style="width: 400rpx;">编码:{{item.matnr}}</text></view>
                  <view><text style="width: 400rpx;">品名:{{item.maktx}}</text></view>
                  <view><text style="width: 400rpx;">批号:{{item.batch}}</text></view>
@@ -61,14 +66,26 @@
            </view>
         </checkbox-group>
      </scroll-view>
      <!-- 底部按钮 -->
      <view class="footer flex justify-around">
         <view>
            <button class="cu-btn lg" @click="resst()">重置</button>
         </view>
         <view>
            <button class="cu-btn lg pakin-btn bg-blue" @click="comb()">组托</button>
         </view>
         <!-- <label class="label-btn" style="width: 170rpx;">
            <checkbox :checked="check" @click="allChecked()">{{checkText}}</checkbox>
         </label>
         <label class="label-btn" style="width: 100rpx;">
            <text  @click="reChecked()">反选</text>
         </label> -->
         <label class="label-btn" style="width: 150rpx;">
            <button class="cu-btn" @click="resst()">重置</button>
         </label>
         <label class="label-btn">
            <button class="cu-btn bg-blue " @click="comb()">组托</button>
         </label>
      </view>
      <!-- 弹窗 -->
      <!-- 修改数量 -->
      <uni-popup ref="revise" background-color="#fff" @change="change">
         <view class="revise-box">
@@ -89,7 +106,6 @@
                  <button class="cu-btn bg-blue" @click="confirm()">确认</button>
               </view>
            </view>
         </view>
      </uni-popup>
   </view>
@@ -114,11 +130,14 @@
            minCount:0,
            maxCount:'',
            rowNum:'',
            check:false,
            checkText:'全选',
            checkedData:[],
         }
      },
      onShow() {
         setTimeout(()=>{
            this.focuss()
            // this.focuss()
         }, 100);
         
      },
@@ -166,7 +185,7 @@
         resst() {
            this.matList = []
            this.barcode = ''
            this.focuss()
            this.barcodeFocuss()
            uni.vibrateShort();
         },
         removeBarcode() {
@@ -185,8 +204,14 @@
               this.focus = true;
            });
         },
         remove(item,index) {
            this.matList.splice(index,1)
         remove() {
            // this.matList.splice(index,1)
            for (var i = 0; i < this.matList.length; i++) {
               if (this.matList[i].checked == true) {
                  this.matList.splice(i,1)
               }
            }
            this.checkList();
            uni.vibrateShort();
         },
         comb() {
@@ -276,7 +301,7 @@
                            // 为指定事件添加一个监听器,获取被打开页面传送到当前页面的数据
                            matList: function(data) {
                              that.matList.push(data.data)
                              console.log(that.matList)
                           },
                        },
                        success: function(res) {
@@ -300,7 +325,7 @@
            this.$refs.goodsSearch.open(type)
         },
         checkbox: function (e) {
            var items = this.data,
            var items = this.matList,
               values = e.detail.value;
            for (var i = 0, lenI = items.length; i < lenI; ++i) {
               const item = items[i]
@@ -343,6 +368,57 @@
            this.matList[this.rowNum].anfme = this.count
            this.$refs.revise.close()
         },
         // 列表反选
         reChecked() {
            if (this.matList.length == 0) {
               return;
            }
            var checkArr = []
            for (var i = 0; i < this.matList.length;i++) {
               if (this.matList[i].checked == true) {
                  this.$set(this.matList[i],'checked',false)
               }else{
                  this.$set(this.matList[i],'checked',true)
               }
               if (this.matList[i].checked == true) {
                  checkArr.push(this.matList[i].checked)
               }
            }
            if (checkArr.length == this.matList.length) {
               this.check = true
               this.checkText = "取消全选"
            } else {
               this.check = false
               this.checkText = "全选"
            }
            uni.vibrateShort();
         },
         // 列表全选
         allChecked(e){
            if (this.check == true) {
               for (var i = 0; i < this.matList.length;i++) {
                  this.$set(this.matList[i],'checked',false)
               }
               this.check = false
               this.checkText = "全选"
            } else {
               for (var i = 0; i < this.matList.length;i++) {
                  this.$set(this.matList[i],'checked',true)
               }
               this.check = true
               this.checkText = "取消全选"
            }
            uni.vibrateShort();
         },
         // 检验列表长度 等于0 显示全选
         checkList() {
            if (this.matList.length == 0) {
               this.check = false
               this.checkText = "全选"
               return;
            }
         }
      }
   }
</script>