中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue中全選組件封裝的示例分析

發布時間:2022-02-13 17:57:27 來源:億速云 閱讀:151 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關vue中全選組件封裝的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

效果

vue中全選組件封裝的示例分析

 封裝的組件

<template>
  <el-form-item :label="label">
    <el-checkbox :indeterminate="isIndeterminateBool" v-model="checkAll"
                 @change="handleCheckAllChange">全選
    </el-checkbox>
    <el-checkbox-group v-model="checkList" @change="handleCheckedCitiesChange">
      <el-checkbox :label="key" v-for="(item,key) in this.channelList"
                   :key="key">{{ item }}
      </el-checkbox>
    </el-checkbox-group>
  </el-form-item>
</template>
<script>
import {channelList} from "@/utils/app-channel";
export default {
  name: "Index",
  data() {
    return {
      //渠道列表 全部渠道
      channelList: channelList,
      //  checkbox 的不確定狀態,一般用于實現全選的效果
      isIndeterminateBool: true,
      //全選默認不勾選
      checkAll: false,
      data: this.checkList,
    }
  },
  computed: {
    checkList: {
      get: function () {
        return (this.item[this.formDBName] || '').split("|").filter(str => (!!str));
      },
      set: function (newValue) {
        this.item[this.formDBName] = newValue.join("|");
      }
    }
  },
  props: {
    //表單名稱
    label: {
      type: String,
      required: true
    },
    //當前選中項
    item: {
      type: Object,
      required: true
    },
    formDBName: {
      type: String,
      required: true
    }
  },
  methods: {
    getArrayCheckList() {
      return (this.item[this.formDBName] || '').split("|").filter(str => (!!str));
    },
    //將數據返回給父組件
    setChooseData(data) {
      this.$emit("choose-data", this.formDBName, data)
    },
    //value 代表選中還是未選中 ture false兩個取值
    handleCheckAllChange(value) {
      const chooseChannel = Object.keys(this.channelList)
      this.checkList = value ? chooseChannel : [];
      this.isIndeterminateBool = false;
      this.checkAll = value;
      const formData = this.checkList.join("|");
      this.setChooseData(formData)
    },
    //選中后計算全選
    handleCheckedCitiesChange(value) {
      const chooseChannel = Object.keys(this.channelList);
      let checkedCount = value.length;
      this.checkAll = checkedCount === chooseChannel.length;
      this.isIndeterminateBool = checkedCount > 0 && checkedCount < chooseChannel.length;
      const formData = value.join("|");
      this.setChooseData(formData)
    },
  },
  mounted() {
    // .split("|").filter(str => (!!str && typeof (str) == 'string'))
  }
}
</script>
<style scoped>
</style>

渠道列表 

vue中全選組件封裝的示例分析

//
export const channelList = {
    "anguo": "安果",
    "baidu": "百度",
    "huawei": "華為",
    "samsung": "三星",
    "oppo": "OPPO",
    "sanliuling": "360",
    "meizu": "魅族",
    "vivo": "VIVO",
    "wandoujia": "豌豆莢",
    "xiaomi": "小米",
    "yyb": "應用寶",
    "yyh": "應用匯",
};

父組件使用

    <el-card shadow="hover">
            <multiple-choice :item="item" label="渠道/廣告開關"
                             form-d-b-name="channel" @choose-data="onCheckResult"></multiple-choice>
          </el-card>

item[channle] 是存入字符串的以|分割的數據

比如

baidu|anguo|yyb

這樣

onCheckResult
   onCheckResult(dbName, res) {
      this.item[dbName] = res;
    }

關于“vue中全選組件封裝的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

砚山县| 高雄市| 凌云县| 海原县| 临夏县| 天等县| 黄山市| 永宁县| 布拖县| 神池县| 成武县| 德钦县| 焉耆| 大田县| 和田县| 库伦旗| 抚州市| 垫江县| 柳江县| 双流县| 宁都县| 桐乡市| 曲沃县| 巴楚县| 绥江县| 永修县| 锦州市| 和平区| 阳春市| 唐山市| 揭阳市| 灵寿县| 十堰市| 班戈县| 阿城市| 南溪县| 陵水| 利辛县| 南雄市| 托里县| 甘孜|