element-ui後臺管理系統學習(12)-vuex使用後的組件抽離

在頁面很複雜的時候,我們可以進行頁面組件的抽離,簡化頁面的複雜度。具體實例如下:

第1步:新建子組件src/compinents/shop/create/base-create.vue

<template>
  <el-form ref="form" label-width="80px">
    <el-form-item label="商品名稱">
      <el-input :value="title" @input="vModel('title',$event)" placeholder="請輸入商品名稱,不能超過60個字符" class="w-50"></el-input>
    </el-form-item>
    <el-form-item label="商品分類">
      <el-cascader :value="category" @input="vModel('category',$event)" :options="options"></el-cascader>
    </el-form-item>
    <el-form-item label="商品描述">
      <el-input type="textarea" :value="desc" @input="vModel('desc',$event)"
        placeholder="選填,商品賣點簡述,例如:此款商品美觀大方 性價比較高 不容錯過" class="w-50"></el-input>
    </el-form-item>
    <el-form-item label="商品單位">
      <el-input :value="unit" @input="vModel('unit',$event)" placeholder="請輸入商品單位" class="w-50"></el-input>
    </el-form-item>
    <el-form-item label="總庫存">
      <el-input type="number" :value="stock" @input="vModel('stock',$event)" class="w-25">
        <template slot="append">件</template>
      </el-input>
    </el-form-item>
    <el-form-item label="庫存預警">
      <el-input type="number" :value="min_stock" @input="vModel('min_stock',$event)" class="w-25">
        <template slot="append">件</template>
      </el-input>
    </el-form-item>
    <el-form-item label="庫存顯示">
      <el-radio-group :value="display_stock" @input="vModel('display_stock',$event)">
        <el-radio :label="1" border>是</el-radio>
        <el-radio :label="0" border>否</el-radio>
      </el-radio-group>
    </el-form-item>
    <el-form-item label="是否上架">
      <el-radio-group :value="status" @input="vModel('status',$event)">
        <el-radio :label="0" border>放入倉庫</el-radio>
        <el-radio :label="1" border>立即上架</el-radio>
      </el-radio-group>
    </el-form-item>
    <el-form-item label="運費模板">
      <el-select :value="express" @input="vModel('express',$event)" placeholder="請選擇運費模板">
        <el-option label="區域一" value="shanghai"></el-option>
        <el-option label="區域二" value="beijing"></el-option>
      </el-select>
    </el-form-item>
  </el-form>
</template>
<script>
import { mapState, mapMutations } from "vuex";
export default {
  data() {
    return {
      tabIndex: 0,
      options: [
        {
          value: "zhinan",
          label: "指南",
          children: [
            {
              value: "shejiyuanze",
              label: "設計原則",
              children: [
                {
                  value: "yizhi",
                  label: "一致"
                },
                {
                  value: "fankui",
                  label: "反饋"
                },
                {
                  value: "xiaolv",
                  label: "效率"
                },
                {
                  value: "kekong",
                  label: "可控"
                }
              ]
            },
            {
              value: "daohang",
              label: "導航",
              children: [
                {
                  value: "cexiangdaohang",
                  label: "側向導航"
                },
                {
                  value: "dingbudaohang",
                  label: "頂部導航"
                }
              ]
            }
          ]
        },
        {
          value: "zujian",
          label: "組件",
          children: [
            {
              value: "basic",
              label: "Basic",
              children: [
                {
                  value: "layout",
                  label: "Layout 佈局"
                },
                {
                  value: "color",
                  label: "Color 色彩"
                },
                {
                  value: "typography",
                  label: "Typography 字體"
                },
                {
                  value: "icon",
                  label: "Icon 圖標"
                },
                {
                  value: "button",
                  label: "Button 按鈕"
                }
              ]
            },
            {
              value: "form",
              label: "Form",
              children: [
                {
                  value: "radio",
                  label: "Radio 單選框"
                },
                {
                  value: "checkbox",
                  label: "Checkbox 多選框"
                },
                {
                  value: "input",
                  label: "Input 輸入框"
                },
                {
                  value: "input-number",
                  label: "InputNumber 計數器"
                },
                {
                  value: "select",
                  label: "Select 選擇器"
                },
                {
                  value: "cascader",
                  label: "Cascader 級聯選擇器"
                },
                {
                  value: "switch",
                  label: "Switch 開關"
                },
                {
                  value: "slider",
                  label: "Slider 滑塊"
                },
                {
                  value: "time-picker",
                  label: "TimePicker 時間選擇器"
                },
                {
                  value: "date-picker",
                  label: "DatePicker 日期選擇器"
                },
                {
                  value: "datetime-picker",
                  label: "DateTimePicker 日期時間選擇器"
                },
                {
                  value: "upload",
                  label: "Upload 上傳"
                },
                {
                  value: "rate",
                  label: "Rate 評分"
                },
                {
                  value: "form",
                  label: "Form 表單"
                }
              ]
            },
            {
              value: "data",
              label: "Data",
              children: [
                {
                  value: "table",
                  label: "Table 表格"
                },
                {
                  value: "tag",
                  label: "Tag 標籤"
                },
                {
                  value: "progress",
                  label: "Progress 進度條"
                },
                {
                  value: "tree",
                  label: "Tree 樹形控件"
                },
                {
                  value: "pagination",
                  label: "Pagination 分頁"
                },
                {
                  value: "badge",
                  label: "Badge 標記"
                }
              ]
            },
            {
              value: "notice",
              label: "Notice",
              children: [
                {
                  value: "alert",
                  label: "Alert 警告"
                },
                {
                  value: "loading",
                  label: "Loading 加載"
                },
                {
                  value: "message",
                  label: "Message 消息提示"
                },
                {
                  value: "message-box",
                  label: "MessageBox 彈框"
                },
                {
                  value: "notification",
                  label: "Notification 通知"
                }
              ]
            },
            {
              value: "navigation",
              label: "Navigation",
              children: [
                {
                  value: "menu",
                  label: "NavMenu 導航菜單"
                },
                {
                  value: "tabs",
                  label: "Tabs 標籤頁"
                },
                {
                  value: "breadcrumb",
                  label: "Breadcrumb 麪包屑"
                },
                {
                  value: "dropdown",
                  label: "Dropdown 下拉菜單"
                },
                {
                  value: "steps",
                  label: "Steps 步驟條"
                }
              ]
            },
            {
              value: "others",
              label: "Others",
              children: [
                {
                  value: "dialog",
                  label: "Dialog 對話框"
                },
                {
                  value: "tooltip",
                  label: "Tooltip 文字提示"
                },
                {
                  value: "popover",
                  label: "Popover 彈出框"
                },
                {
                  value: "card",
                  label: "Card 卡片"
                },
                {
                  value: "carousel",
                  label: "Carousel 走馬燈"
                },
                {
                  value: "collapse",
                  label: "Collapse 摺疊面板"
                }
              ]
            }
          ]
        },
        {
          value: "ziyuan",
          label: "資源",
          children: [
            {
              value: "axure",
              label: "Axure Components"
            },
            {
              value: "sketch",
              label: "Sketch Templates"
            },
            {
              value: "jiaohu",
              label: "組件交互文檔"
            }
          ]
        }
      ]
    };
  },
  computed: {
    ...mapState({
      title: state => state.goods_create.title,
      category: state => state.goods_create.category,
      desc: state => state.goods_create.desc,
      unit: state => state.goods_create.unit,
      stock: state => state.goods_create.stock,
      min_stock: state => state.goods_create.min_stock,
      display_stock: state => state.goods_create.display_stock,
      status: state => state.goods_create.status,
      express: state => state.goods_create.express
    })
  },
  methods: {
    ...mapMutations(["vModelState"]),
    // 修改表單的值
    vModel(key, value) {
      this.vModelState({ key, value });
    }
  }
};
</script>
<style >
</style>

注意:我們需要將對應的該組件的data、methods、computed都要抽離出來,但是我們不需要考慮怎麼傳值,方法如何調用等等。

第2步:在父組件中引入子組件base-create.vue與vuex,刪除已經抽離出來的data、methods、computed等等


<base-create></base-create>


import { mapState, mapMutations } from "vuex";
import baseCreate from "@/components/shop/create/base-create";

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章