前端插件的应用

news2025/1/8 4:00:56

 像这种页面四个页面下面的展示格式都一样,这个时候就把公共部分代码抽取出来作为组件使用

直接把中间部分代码赋值过来

<template>

  <div>

    <div v-for="(items, index) in ford" :key="index">

      <div v-if="items.shopCode != null">

        <div class="title_stle">

          <h3 v-if="inx === '0'" class="tar_stle">天猫</h3>

          <h3 v-if="inx === '1'" class="tar_stle">唯品</h3>

          <h3 v-if="inx === '2'" class="tar_stle">抖音旗舰店</h3>

          <h3 v-if="inx === '3'" class="tar_stle">抖音构美店</h3>

          <div>

            <h3

              class="tar_stle01"

              :class="inx == '2' || inx == '3' ? 'sp05' : ''"

            >

              活动仓<span class="span_stal">{{

                items.activityWarehouseName

              }}</span>

            </h3>

            <h3

              class="tar_stle02"

              :class="

                inx == '1'

                  ? 'sp02'

                  : inx == '2'

                  ? 'sp03'

                  : inx == '3'

                  ? 'sp03'

                  : 'sp04'

              "

            >

              独占仓<span class="span_stal">{{

                items.exclusiveWarehouseName

              }}</span>

            </h3>

            <h3 class="tar_stle03">

              共享仓<span class="span_stal">{{

                items.shareWarehouseName

              }}</span>

            </h3>

            <div class="button_style">

              <el-button type="primary" size="medium" @click="saveRegulations"

                >保存</el-button

              >

            </div>

          </div>

        </div>

        <div class="content">

          <div class="tableBoxTitle">

            独占判断

            <div class="tableBoxContent">

              <div

                class="elDivClass"

                v-for="item in (items.regulationDetailList || []).filter(

                  (item) => item.type == '01'

                )"

                :key="item.id"

              >

                <el-checkbox

                  v-model="item.participation"

                  class="elCheckBoxClass"

                  :label="item.parameterName"

                >

                  <span class="checkoutlabelClass">{{

                    item.stringArray[0]

                  }}</span>

                  <span class="symBolTextClass">{{ item.stringArray[1] }}</span>

                  <span class="inputSpanClass"

                    ><el-input

                      class="inputClass"

                      v-model="item.parameterValue"

                      οnkeypress="return event.keyCode>=48&&event.keyCode<=57"

                      οnpaste="return !clipboardData.getData('text').math(/\D/)"

                      οndragenter="return false"

                      maxlength="8"

                    >

                    </el-input

                  ></span>

                  <span

                    v-if="

                      item.stringArray.length > 0 &&

                      item.stringArray.length == 4

                    "

                    class="utilText"

                    >{{ item.stringArray[3] }}</span

                  >

                </el-checkbox>

              </div>

            </div>

          </div>

        </div>

        <div class="share_content">

          <div class="tableBoxTitle">

            共享判定

            <div class="tableBoxContent">

              <div

                class="elDivClass"

                v-for="item in (items.regulationDetailList || []).filter(

                  (item) => item.type == '02'

                )"

                :key="item.id"

              >

                <el-checkbox

                  v-model="item.participation"

                  class="elCheckBoxClass"

                  :label="item.parameterName"

                >

                  <span class="checkoutlabelClass">{{

                    item.stringArray[0]

                  }}</span>

                  <span class="symBolTextClass">{{ item.stringArray[1] }}</span>

                  <span class="inputSpanClass"

                    ><el-input

                      class="inputClass"

                      v-model="item.parameterValue"

                      οnkeypress="return event.keyCode>=48&&event.keyCode<=57"

                      οnpaste="return !clipboardData.getData('text').math(/\D/)"

                      οndragenter="return false"

                      maxlength="8"

                    >

                    </el-input

                  ></span>

                  <span

                    v-if="

                      item.stringArray.length > 0 &&

                      item.stringArray.length == 4

                    "

                    class="utilText"

                    >{{ item.stringArray[3] }}</span

                  >

                </el-checkbox>

              </div>

            </div>

          </div>

        </div>

        <div class="general_content">

          <div class="general_tableBoxTitle">

            通用

            <div class="tableBoxContent">

              <div

                class="elDivClass"

                v-for="item in (items.regulationDetailList || []).filter(

                  (item) => item.type == '03'

                )"

                :key="item.id"

              >

                <el-checkbox

                  v-model="item.participation"

                  class="elCheckBoxClass"

                  :label="item.parameterName"

                >

                  <span class="checkoutlabelClass">{{

                    item.stringArray[0]

                  }}</span>

                  <span class="symBolTextClass">{{ item.stringArray[1] }}</span>

                  <span class="inputSpanClass"

                    ><el-input

                      class="inputClass"

                      v-model="item.parameterValue"

                      οnkeypress="return event.keyCode>=48&&event.keyCode<=57"

                      οnpaste="return !clipboardData.getData('text').math(/\D/)"

                      οndragenter="return false"

                      maxlength="8"

                    >

                    </el-input

                  ></span>

                  <span

                    v-if="

                      item.stringArray.length > 0 &&

                      item.stringArray.length == 4

                    "

                    class="utilText"

                    >{{ item.stringArray[3] }}</span

                  >

                </el-checkbox>

              </div>

            </div>

          </div>

        </div>

        <div class="people_content">

          <div class="people_tableBoxTitle">

            人工指定

            <div

              v-for="item in (items.regulationDetailList || []).filter(

                (item) =>

                  item.parameterCode == 'SHOP.ALLOT.EXCLUSIVE.PRODUCT.HOLDUP'

              )"

              :key="item.id"

              class="people_BoxContent"

            >

              <h3 class="within_Content">独占款</h3>

              <textarea

                v-if="

                  item.parameterCode != null &&

                  item.parameterCode == 'SHOP.ALLOT.EXCLUSIVE.PRODUCT.HOLDUP'

                "

                v-model="item.parameterValue"

                class="specialinput"

                placeholder="多个款号请用逗号隔开!"

                οnkeypress="javascript:if(event.keyCode == 32 || event.keyCode == 13)event.returnValue = false;"

              ></textarea>

            </div>

            <div

              class="people_BoxContent special"

              v-for="item in (items.regulationDetailList || []).filter(

                (item) =>

                  item.parameterCode == 'SHOP.ALLOT.SHARE.PRODUCT.HOLDUP'

              )"

              :key="item.id"

            >

              <h3 class="within_Content">共享款</h3>

              <textarea

                v-if="

                  item.parameterCode != null &&

                  item.parameterCode == 'SHOP.ALLOT.SHARE.PRODUCT.HOLDUP'

                "

                v-model="item.parameterValue"

                class="specialinput"

                placeholder="多个款号请用逗号隔开!"

                οnkeypress="javascript:if(event.keyCode == 32 || event.keyCode == 13)event.returnValue = false;"

              ></textarea>

            </div>

          </div>

        </div>

      </div>

    </div>

  </div>

</template>

<script>

export default {

  props: ["inx", "ford"],

  data() {

    return {

      pagination: {},

      regulations: [],

      tabIndex: "0",

      copy: [],

    };

  },

  watch: {

    inx(nv, ov) {

      this.regulations = this.ford;

    },

  },

  created() {

    this.init();

  },

  mounted() {},

  methods: {

    init() {},

    //1.查询所有规则信息

    queryRegulations() {

      let _self = this;

      const pageLoading = _self.openLoading(); //调用方法,打开loading遮罩层

      _self.$http

        .post(_self.$api.queryRegulationInfos)

        .then(function (response) {

          pageLoading.close(); //请求成功之后就关闭遮罩层

          if (response.data.code == "1") {

            //赋值操作[0为有效状态]

            const newData = response.data.data;

            if (newData && newData.length > 0) {

              newData.map((item) => {

                if (

                  item.regulationDetailList &&

                  item.regulationDetailList.length > 0

                ) {

                  item.regulationDetailList.map((detailItem) => {

                    detailItem.participation = detailItem.participation == "0";

                  });

                }

              });

            }

            //解析规则明细字段

            if (newData && newData.length > 0) {

              newData.map((item) => {

                if (

                  item.regulationDetailList &&

                  item.regulationDetailList.length > 0

                ) {

                  item.regulationDetailList.map((detailItem) => {

                    let stringArry = detailItem.expression.split("|");

                    detailItem["stringArray"] = stringArry;

                  });

                }

              });

            }

            console.log(newData, "newDatanewData");

            _self.regulations = newData;

          } else {

            _self.$message.error(response.data.message);

          }

        });

    },

    //2.保存

    saveRegulations() {

      this.$emit("forUpdate", this.ford);

    },

    //调用修改接口

    updateRegulations(parameterData) {

      let _self = this;

      const pageLoading = _self.openLoading(); //调用方法,打开loading遮罩层

      _self.$http

        .post(_self.$api.updateRegulations, this.ford)

        .then(function (response) {

          pageLoading.close(); //请求成功之后就关闭遮罩层

          if (response.data.code == "1") {

            _self.$message.success({ message: "保存成功!" });

            _self.queryRegulations();

          } else {

            _self.$message.error(response.data.message);

          }

        });

    },

    //全局加载loading图标

    openLoading() {

      const loading = this.$loading({

        lock: true,

        fullScreen: true,

        background: "rgba(255,255,255,0.7)",

      });

      return loading;

    },

  },

};

</script>

<style lang="less" scoped>

.regulation-tag {

  height: 100%;

  background-color: #fff;

  .rfm-model-header {

    height: 30px;

    margin-bottom: 10px;

  }

  .rfm-model-header > span {

    display: block;

    float: left;

    line-height: 60px;

  }

  .rfm-model-header-title {

    width: 120px;

    float: left;

    font-weight: 500;

    margin-top: 10px;

  }

  .tool-bar {

    font-size: 12px;

    color: #fff;

    overflow: auto;

    padding: 5px 0;

  }

  .el-tab-pane {

    height: calc(100% - 40px);

  }

  .tar-tianMao {

    height: 100px;

    background-color: pink;

  }

  .tar-tianMao h4 {

    display: inline-block;

  }

  .content {

    float: left;

    position: relative;

    display: block;

    width: 400px;

    height: 450px;

    border: 1px solid #999;

    margin-top: 10px;

    margin-left: 30px;

  }

  .tableBoxTitle {

    display: inline-block;

    width: 70px;

    height: 60px;

    background-color: #fff;

    position: absolute;

    top: -12px;

    left: 14px;

    padding: 0 6px;

  }

  .tableBoxContent {

    width: 100%;

    height: auto;

    box-sizing: border-box;

    padding: 20px;

  }

  .share_content {

    position: relative;

    display: inline-block;

    width: 400px;

    height: 450px;

    border: 1px solid #999;

    margin-top: 10px;

    margin-left: 40px;

  }

  .general_content {

    position: relative;

    display: inline-block;

    width: 400px;

    height: 450px;

    border: 1px solid #999;

    margin-top: 10px;

    margin-left: 40px;

  }

  .general_tableBoxTitle {

    display: inline-block;

    width: 35px;

    height: 60px;

    background-color: #fff;

    position: absolute;

    top: -12px;

    left: 14px;

    padding: 0 6px;

  }

  .people_content {

    position: relative;

    margin-left: 30px;

    margin-top: 20px;

    width: 1290px;

    height: 250px;

    border: 1px solid #999;

  }

  .people_tableBoxTitle {

    display: inline-block;

    width: 70px;

    height: 50px;

    background-color: #fff;

    position: absolute;

    top: -12px;

    left: 14px;

    padding: 0 6px;

  }

  .people_BoxContent {

    display: inline-block;

    margin-top: 30px;

    width: 623px;

    height: 180px;

    background-color: #fff;

    border: 1px solid #999;

  }

  .special {

    position: absolute;

    top: 21px;

    left: 629px;

  }

  .specialinput {

    width: 100%;

    height: 125px;

    //border: none !important;

  }

  .within_Content {

    height: 40px;

    background-color: #fff;

    text-align: center;

    padding-top: 10px;

    border: 1px solid #ccc;

  }

  .title_stle {

    margin-top: 0px;

    height: 100px;

    background-color: #fff;

  }

  .tar_stle {

    margin-left: 30px;

    padding-top: 35px;

  }

  .tar_stle01 {

    float: left;

    margin-left: 120px;

    //  padding-left: 200px;

  }

  .sp05 {

    float: left;

    margin-left: 180px;

    //  padding-left: 200px;

  }

  .gou_stle01 {

    float: left;

    margin-left: 180px;

    //  padding-left: 200px;

  }

  .dou_stle01 {

    float: left;

    margin-left: 170px;

    //  padding-left: 200px;

  }

  .tar_stle02 {

    position: relative;

    top: -45px;

    // left: -20px;

    // padding-top: -80px;

    //  padding-left: 200px;

  }

  .sp02 {

    left: -227px !important;

  }

  .sp03 {

    left: -77px !important;

  }

  .sp04 {

    left: -305px !important;

  }

  .gou_stle02 {

    position: relative;

    top: -45px;

    left: -75px;

    // padding-top: -80px;

    //  padding-left: 200px;

  }

  .wei_stle01 {

    position: relative;

    top: -45px;

    left: -220px;

    // padding-top: -80px;

    //  padding-left: 200px;

  }

  .dou_stle02 {

    position: relative;

    top: -45px;

    left: -75px;

    // padding-top: -80px;

    //  padding-left: 200px;

  }

  .span_stal {

    margin-left: 20px;

  }

  .tar_stle03 {

    position: relative;

    top: -45px;

    left: 480px;

  }

  .button_style {

    position: relative;

    top: -55px;

    left: 1200px;

  }

  .elDivClass {

    margin-top: 10px;

  }

  /* .elCheckBoxClass{

        display: block;

        margin-top: 20px;

    } */

  .checkoutlabelClass {

    width: 130px;

    display: inline-block;

  }

  .symBolTextClass {

    width: 60px;

    display: inline-block;

    margin-right: 10px;

  }

  .inputSpanClass {

    width: 200px;

  }

  .inputClass {

    width: 25%;

  }

}

</style>

定义模板,注册,使用

<template>

  <div class="regulation-tag">

    <div class="rfm-model-header">

      <h4 class="rfm-model-header-title" style="width: 120px">规则配置</h4>

    </div>

    <el-tabs v-model="tabIndex" type="card" @tab-click="tabChange">

      <el-tab-pane :key="0" label="天猫" name="0">

        <com :inx="tabIndex" :ford="forData" @forUpdate="saveRegulations"></com>

      </el-tab-pane>

      <el-tab-pane :key="1" label="唯品" name="1">

        <com :inx="tabIndex" :ford="forData" @forUpdate="saveRegulations"></com>

      </el-tab-pane>

      <el-tab-pane :key="2" label="抖音旗舰店" name="2">

        <com :inx="tabIndex" :ford="forData" @forUpdate="saveRegulations"></com>

      </el-tab-pane>

      <el-tab-pane :key="3" label="抖音构美店" name="3">

        <com :inx="tabIndex" :ford="forData" @forUpdate="saveRegulations"></com>

      </el-tab-pane>

    </el-tabs>

  </div>

</template>

<script>

import tableBox from "./components/tableBox/index.vue";

import com from "./components/com.vue";

export default {

  components: { tableBox, com },

  data() {

    return {

      pagination: {},

      regulations: [],

      tabIndex: "0",

      forData: [],

      tabInx: 0,

    };

  },

  created() {

    this.init();

  },

  mounted() {},

  methods: {

    init() {

      let _self = this;

      //初始化数据

      _self.queryRegulations();

      //_self.deleteString();

    },

    //1.查询所有规则信息

    queryRegulations() {

      let _self = this;

      const pageLoading = _self.openLoading(); //调用方法,打开loading遮罩层

      _self.$http

        .post(_self.$api.queryRegulationInfos)

        .then(function (response) {

          pageLoading.close(); //请求成功之后就关闭遮罩层

          if (response.data.code == "1") {

            //赋值操作[0为有效状态]

            const newData = response.data.data;

            if (newData && newData.length > 0) {

              newData.map((item) => {

                if (

                  item.regulationDetailList &&

                  item.regulationDetailList.length > 0

                ) {

                  item.regulationDetailList.map((detailItem) => {

                    detailItem.participation = detailItem.participation == "0";

                  });

                }

              });

            }

            //解析规则明细字段

            if (newData && newData.length > 0) {

              newData.map((item) => {

                if (

                  item.regulationDetailList &&

                  item.regulationDetailList.length > 0

                ) {

                  item.regulationDetailList.map((detailItem) => {

                    let stringArry = detailItem.expression.split("|");

                    detailItem["stringArray"] = stringArry;

                  });

                }

              });

            }

            _self.regulations = newData;

            let data = newData[this.tabInx];

            this.forData = [];

            this.forData.push(data);

          } else {

            _self.$message.error(response.data.message);

          }

        });

    },

    //2.保存

    saveRegulations(parameterData) {

      // this.updateRegulations(parameterData);

      let _self = this;

      //const pageLoading = _self.openLoading(); //调用方法,打开loading遮罩层

      //勾选数据进行还原

      if (_self.regulations && _self.regulations.length > 0) {

        _self.regulations.map((item) => {

          if (

            item.regulationDetailList &&

            item.regulationDetailList.length > 0

          ) {

            item.regulationDetailList.map((detailItem) => {

              detailItem.participation = detailItem.participation ? "0" : "1";

            });

          }

        });

      }

      //tabIndex 为0代表天猫店1唯品店2抖音旗舰店3构美店

      if (_self.tabIndex != null && _self.tabIndex === "0") {

        if (_self.regulations && _self.regulations.length > 0) {

          //过滤出天猫门店数据

          const parameterData = _self.regulations.filter((item) => {

            if (item.shopCode != null && item.shopCode === "TM-ES") {

              return true;

            } else {

              return false;

            }

          });

          _self.updateRegulations(parameterData);

        }

      }

      //过滤出唯品会数据

      if (_self.tabIndex != null && _self.tabIndex === "1") {

        if (_self.regulations && _self.regulations.length > 0) {

          //过滤出唯品门店数据

          const parameterData = _self.regulations.filter((item) => {

            if (item.shopCode != null && item.shopCode === "WPH-ES") {

              return true;

            } else {

              return false;

            }

          });

          _self.updateRegulations(parameterData);

        }

      }

      //过滤出抖音旗舰店数据

      if (_self.tabIndex != null && _self.tabIndex === "2") {

        if (_self.regulations && _self.regulations.length > 0) {

          //过滤出唯品门店数据

          const parameterData = _self.regulations.filter((item) => {

            if (item.shopCode != null && item.shopCode === "ESDYQJD") {

              return true;

            } else {

              return false;

            }

          });

          _self.updateRegulations(parameterData);

        }

      }

      //过滤出抖音旗舰店数据

      if (_self.tabIndex != null && _self.tabIndex === "3") {

        if (_self.regulations && _self.regulations.length > 0) {

          //过滤出唯品门店数据

          const parameterData = _self.regulations.filter((item) => {

            if (item.shopCode != null && item.shopCode === "ESDYDYY") {

              return true;

            } else {

              return false;

            }

          });

          _self.updateRegulations(parameterData);

        }

      }

    },

    //调用修改接口

    updateRegulations(parameterData) {

      let _self = this;

      const pageLoading = _self.openLoading(); //调用方法,打开loading遮罩层

      _self.$http

        .post(_self.$api.updateRegulations, parameterData)

        .then(function (response) {

          pageLoading.close(); //请求成功之后就关闭遮罩层

          if (response.data.code == "1") {

            _self.$message.success({ message: "保存成功!" });

            _self.queryRegulations();

          } else {

            _self.$message.error(response.data.message);

          }

        });

    },

    tabChange(tab) {

      let _self = this;

      _self.tabIndex = tab.index;

      this.tabInx = parseInt(tab.index);

      _self.pagination = {};

      if (tab.index === "0") {

        let data = this.regulations[0];

        this.forData = [];

        this.forData.push(data);

      }

      if (tab.index === "1") {

        let data = this.regulations[1];

        this.forData = [];

        this.forData.push(data);

      }

      if (tab.index === "2") {

        let data = this.regulations[2];

        this.forData = [];

        this.forData.push(data);

      }

      if (tab.index === "3") {

        let data = this.regulations[3];

        this.forData = [];

        this.forData.push(data);

      }

    },

    //全局加载loading图标

    openLoading() {

      const loading = this.$loading({

        lock: true,

        fullScreen: true,

        background: "rgba(255,255,255,0.7)",

      });

      return loading;

    },

  },

};

</script>

<style lang="scss">

.regulation-tag {

  height: 100%;

  background-color: #fff;

  .rfm-model-header {

    height: 30px;

    margin-bottom: 10px;

  }

  .rfm-model-header > span {

    display: block;

    float: left;

    line-height: 60px;

  }

  .rfm-model-header-title {

    width: 120px;

    float: left;

    font-weight: 500;

    margin-top: 10px;

  }

  .tool-bar {

    font-size: 12px;

    color: #fff;

    overflow: auto;

    padding: 5px 0;

  }

  .el-tab-pane {

    height: calc(100% - 40px);

  }

  .tar-tianMao {

    height: 100px;

    background-color: pink;

  }

  .tar-tianMao h4 {

    display: inline-block;

  }

  .content {

    float: left;

    position: relative;

    display: block;

    width: 400px;

    height: 450px;

    border: 1px solid #999;

    margin-top: 10px;

    margin-left: 30px;

  }

  .tableBoxTitle {

    display: inline-block;

    width: 70px;

    height: 60px;

    background-color: #fff;

    position: absolute;

    top: -12px;

    left: 14px;

    padding: 0 6px;

  }

  .tableBoxContent {

    width: 100%;

    height: auto;

    box-sizing: border-box;

    padding: 20px;

  }

  .share_content {

    position: relative;

    display: inline-block;

    width: 400px;

    height: 450px;

    border: 1px solid #999;

    margin-top: 10px;

    margin-left: 40px;

  }

  .general_content {

    position: relative;

    display: inline-block;

    width: 400px;

    height: 450px;

    border: 1px solid #999;

    margin-top: 10px;

    margin-left: 40px;

  }

  .general_tableBoxTitle {

    display: inline-block;

    width: 35px;

    height: 60px;

    background-color: #fff;

    position: absolute;

    top: -12px;

    left: 14px;

    padding: 0 6px;

  }

  .people_content {

    position: relative;

    margin-left: 30px;

    margin-top: 20px;

    width: 1290px;

    height: 250px;

    border: 1px solid #999;

  }

  .people_tableBoxTitle {

    display: inline-block;

    width: 70px;

    height: 50px;

    background-color: #fff;

    position: absolute;

    top: -12px;

    left: 14px;

    padding: 0 6px;

  }

  .people_BoxContent {

    display: inline-block;

    margin-top: 30px;

    width: 623px;

    height: 180px;

    background-color: #fff;

    border: 1px solid #999;

  }

  .special {

    position: absolute;

    top: 21px;

    left: 629px;

  }

  .specialinput {

    width: 100%;

    height: 125px;

    //border: none !important;

  }

  .within_Content {

    height: 40px;

    background-color: #fff;

    text-align: center;

    padding-top: 10px;

    border: 1px solid #ccc;

  }

  .title_stle {

    height: 100px;

    background-color: #fff;

  }

  .tar_stle {

    margin-left: 30px;

    padding-top: 35px;

  }

  .tar_stle01 {

    float: left;

    margin-left: 120px;

    //  padding-left: 200px;

  }

  .gou_stle01 {

    float: left;

    margin-left: 180px;

    //  padding-left: 200px;

  }

  .dou_stle01 {

    float: left;

    margin-left: 170px;

    //  padding-left: 200px;

  }

  .tar_stle02 {

    position: relative;

    top: -45px;

    // left: -20px;

    // padding-top: -80px;

    //  padding-left: 200px;

  }

  .gou_stle02 {

    position: relative;

    top: -45px;

    left: -75px;

    // padding-top: -80px;

    //  padding-left: 200px;

  }

  .wei_stle01 {

    position: relative;

    top: -45px;

    left: -220px;

    // padding-top: -80px;

    //  padding-left: 200px;

  }

  .dou_stle02 {

    position: relative;

    top: -45px;

    left: -75px;

    // padding-top: -80px;

    //  padding-left: 200px;

  }

  .span_stal {

    margin-left: 20px;

  }

  .tar_stle03 {

    position: relative;

    top: -45px;

    left: 480px;

  }

  .button_style {

    position: relative;

    top: -55px;

    left: 1200px;

  }

  .elDivClass {

    margin-top: 10px;

  }

  /* .elCheckBoxClass{

        display: block;

        margin-top: 20px;

    } */

  .checkoutlabelClass {

    width: 130px;

    display: inline-block;

  }

  .symBolTextClass {

    width: 60px;

    display: inline-block;

    margin-right: 10px;

  }

  .inputSpanClass {

    width: 200px;

  }

  .inputClass {

    width: 25%;

  }

}

</style>

<template>

  <div class="regulation-tag">

    <div class="rfm-model-header">

      <h4 class="rfm-model-header-title" style="width: 120px">规则配置</h4>

    </div>

    <el-tabs v-model="tabIndex" type="card" @tab-click="tabChange">

      <el-tab-pane :key="0" label="天猫" name="0">

        <com :inx="tabIndex" :ford="forData" @forUpdate="saveRegulations"></com>

      </el-tab-pane>

      <el-tab-pane :key="1" label="唯品" name="1">

        <com :inx="tabIndex" :ford="forData" @forUpdate="saveRegulations"></com>

      </el-tab-pane>

      <el-tab-pane :key="2" label="抖音旗舰店" name="2">

        <com :inx="tabIndex" :ford="forData" @forUpdate="saveRegulations"></com>

      </el-tab-pane>

      <el-tab-pane :key="3" label="抖音构美店" name="3">

        <com :inx="tabIndex" :ford="forData" @forUpdate="saveRegulations"></com>

      </el-tab-pane>

    </el-tabs>

  </div>

</template>

<script>

import tableBox from "./components/tableBox/index.vue";

import com from "./components/com.vue";

export default {

  components: { tableBox, com },

  data() {

    return {

      pagination: {},

      regulations: [],

      tabIndex: "0",

      forData: [],

      tabInx: 0,

    };

  },

  created() {

    this.init();

  },

  mounted() {},

  methods: {

    init() {

      let _self = this;

      //初始化数据

      _self.queryRegulations();

      //_self.deleteString();

    },

    //1.查询所有规则信息

    queryRegulations() {

      let _self = this;

      const pageLoading = _self.openLoading(); //调用方法,打开loading遮罩层

      _self.$http

        .post(_self.$api.queryRegulationInfos)

        .then(function (response) {

          pageLoading.close(); //请求成功之后就关闭遮罩层

          if (response.data.code == "1") {

            //赋值操作[0为有效状态]

            const newData = response.data.data;

            if (newData && newData.length > 0) {

              newData.map((item) => {

                if (

                  item.regulationDetailList &&

                  item.regulationDetailList.length > 0

                ) {

                  item.regulationDetailList.map((detailItem) => {

                    detailItem.participation = detailItem.participation == "0";

                  });

                }

              });

            }

            //解析规则明细字段

            if (newData && newData.length > 0) {

              newData.map((item) => {

                if (

                  item.regulationDetailList &&

                  item.regulationDetailList.length > 0

                ) {

                  item.regulationDetailList.map((detailItem) => {

                    let stringArry = detailItem.expression.split("|");

                    detailItem["stringArray"] = stringArry;

                  });

                }

              });

            }

            _self.regulations = newData;

            let data = newData[this.tabInx];

            this.forData = [];

            this.forData.push(data);

          } else {

            _self.$message.error(response.data.message);

          }

        });

    },

    //2.保存

    saveRegulations(parameterData) {

      // this.updateRegulations(parameterData);

      let _self = this;

      //const pageLoading = _self.openLoading(); //调用方法,打开loading遮罩层

      //勾选数据进行还原

      if (_self.regulations && _self.regulations.length > 0) {

        _self.regulations.map((item) => {

          if (

            item.regulationDetailList &&

            item.regulationDetailList.length > 0

          ) {

            item.regulationDetailList.map((detailItem) => {

              detailItem.participation = detailItem.participation ? "0" : "1";

            });

          }

        });

      }

      //tabIndex 为0代表天猫店1唯品店2抖音旗舰店3构美店

      if (_self.tabIndex != null && _self.tabIndex === "0") {

        if (_self.regulations && _self.regulations.length > 0) {

          //过滤出天猫门店数据

          const parameterData = _self.regulations.filter((item) => {

            if (item.shopCode != null && item.shopCode === "TM-ES") {

              return true;

            } else {

              return false;

            }

          });

          _self.updateRegulations(parameterData);

        }

      }

      //过滤出唯品会数据

      if (_self.tabIndex != null && _self.tabIndex === "1") {

        if (_self.regulations && _self.regulations.length > 0) {

          //过滤出唯品门店数据

          const parameterData = _self.regulations.filter((item) => {

            if (item.shopCode != null && item.shopCode === "WPH-ES") {

              return true;

            } else {

              return false;

            }

          });

          _self.updateRegulations(parameterData);

        }

      }

      //过滤出抖音旗舰店数据

      if (_self.tabIndex != null && _self.tabIndex === "2") {

        if (_self.regulations && _self.regulations.length > 0) {

          //过滤出唯品门店数据

          const parameterData = _self.regulations.filter((item) => {

            if (item.shopCode != null && item.shopCode === "ESDYQJD") {

              return true;

            } else {

              return false;

            }

          });

          _self.updateRegulations(parameterData);

        }

      }

      //过滤出抖音旗舰店数据

      if (_self.tabIndex != null && _self.tabIndex === "3") {

        if (_self.regulations && _self.regulations.length > 0) {

          //过滤出唯品门店数据

          const parameterData = _self.regulations.filter((item) => {

            if (item.shopCode != null && item.shopCode === "ESDYDYY") {

              return true;

            } else {

              return false;

            }

          });

          _self.updateRegulations(parameterData);

        }

      }

    },

    //调用修改接口

    updateRegulations(parameterData) {

      let _self = this;

      const pageLoading = _self.openLoading(); //调用方法,打开loading遮罩层

      _self.$http

        .post(_self.$api.updateRegulations, parameterData)

        .then(function (response) {

          pageLoading.close(); //请求成功之后就关闭遮罩层

          if (response.data.code == "1") {

            _self.$message.success({ message: "保存成功!" });

            _self.queryRegulations();

          } else {

            _self.$message.error(response.data.message);

          }

        });

    },

    tabChange(tab) {

      let _self = this;

      _self.tabIndex = tab.index;

      this.tabInx = parseInt(tab.index);

      _self.pagination = {};

      if (tab.index === "0") {

        let data = this.regulations[0];

        this.forData = [];

        this.forData.push(data);

      }

      if (tab.index === "1") {

        let data = this.regulations[1];

        this.forData = [];

        this.forData.push(data);

      }

      if (tab.index === "2") {

        let data = this.regulations[2];

        this.forData = [];

        this.forData.push(data);

      }

      if (tab.index === "3") {

        let data = this.regulations[3];

        this.forData = [];

        this.forData.push(data);

      }

    },

    //全局加载loading图标

    openLoading() {

      const loading = this.$loading({

        lock: true,

        fullScreen: true,

        background: "rgba(255,255,255,0.7)",

      });

      return loading;

    },

  },

};

</script>

<style lang="scss">

.regulation-tag {

  height: 100%;

  background-color: #fff;

  .rfm-model-header {

    height: 30px;

    margin-bottom: 10px;

  }

  .rfm-model-header > span {

    display: block;

    float: left;

    line-height: 60px;

  }

  .rfm-model-header-title {

    width: 120px;

    float: left;

    font-weight: 500;

    margin-top: 10px;

  }

  .tool-bar {

    font-size: 12px;

    color: #fff;

    overflow: auto;

    padding: 5px 0;

  }

  .el-tab-pane {

    height: calc(100% - 40px);

  }

  .tar-tianMao {

    height: 100px;

    background-color: pink;

  }

  .tar-tianMao h4 {

    display: inline-block;

  }

  .content {

    float: left;

    position: relative;

    display: block;

    width: 400px;

    height: 450px;

    border: 1px solid #999;

    margin-top: 10px;

    margin-left: 30px;

  }

  .tableBoxTitle {

    display: inline-block;

    width: 70px;

    height: 60px;

    background-color: #fff;

    position: absolute;

    top: -12px;

    left: 14px;

    padding: 0 6px;

  }

  .tableBoxContent {

    width: 100%;

    height: auto;

    box-sizing: border-box;

    padding: 20px;

  }

  .share_content {

    position: relative;

    display: inline-block;

    width: 400px;

    height: 450px;

    border: 1px solid #999;

    margin-top: 10px;

    margin-left: 40px;

  }

  .general_content {

    position: relative;

    display: inline-block;

    width: 400px;

    height: 450px;

    border: 1px solid #999;

    margin-top: 10px;

    margin-left: 40px;

  }

  .general_tableBoxTitle {

    display: inline-block;

    width: 35px;

    height: 60px;

    background-color: #fff;

    position: absolute;

    top: -12px;

    left: 14px;

    padding: 0 6px;

  }

  .people_content {

    position: relative;

    margin-left: 30px;

    margin-top: 20px;

    width: 1290px;

    height: 250px;

    border: 1px solid #999;

  }

  .people_tableBoxTitle {

    display: inline-block;

    width: 70px;

    height: 50px;

    background-color: #fff;

    position: absolute;

    top: -12px;

    left: 14px;

    padding: 0 6px;

  }

  .people_BoxContent {

    display: inline-block;

    margin-top: 30px;

    width: 623px;

    height: 180px;

    background-color: #fff;

    border: 1px solid #999;

  }

  .special {

    position: absolute;

    top: 21px;

    left: 629px;

  }

  .specialinput {

    width: 100%;

    height: 125px;

    //border: none !important;

  }

  .within_Content {

    height: 40px;

    background-color: #fff;

    text-align: center;

    padding-top: 10px;

    border: 1px solid #ccc;

  }

  .title_stle {

    height: 100px;

    background-color: #fff;

  }

  .tar_stle {

    margin-left: 30px;

    padding-top: 35px;

  }

  .tar_stle01 {

    float: left;

    margin-left: 120px;

    //  padding-left: 200px;

  }

  .gou_stle01 {

    float: left;

    margin-left: 180px;

    //  padding-left: 200px;

  }

  .dou_stle01 {

    float: left;

    margin-left: 170px;

    //  padding-left: 200px;

  }

  .tar_stle02 {

    position: relative;

    top: -45px;

    // left: -20px;

    // padding-top: -80px;

    //  padding-left: 200px;

  }

  .gou_stle02 {

    position: relative;

    top: -45px;

    left: -75px;

    // padding-top: -80px;

    //  padding-left: 200px;

  }

  .wei_stle01 {

    position: relative;

    top: -45px;

    left: -220px;

    // padding-top: -80px;

    //  padding-left: 200px;

  }

  .dou_stle02 {

    position: relative;

    top: -45px;

    left: -75px;

    // padding-top: -80px;

    //  padding-left: 200px;

  }

  .span_stal {

    margin-left: 20px;

  }

  .tar_stle03 {

    position: relative;

    top: -45px;

    left: 480px;

  }

  .button_style {

    position: relative;

    top: -55px;

    left: 1200px;

  }

  .elDivClass {

    margin-top: 10px;

  }

  /* .elCheckBoxClass{

        display: block;

        margin-top: 20px;

    } */

  .checkoutlabelClass {

    width: 130px;

    display: inline-block;

  }

  .symBolTextClass {

    width: 60px;

    display: inline-block;

    margin-right: 10px;

  }

  .inputSpanClass {

    width: 200px;

  }

  .inputClass {

    width: 25%;

  }

}

</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/144077.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

P3- 傅里叶变换1-通讯原理

前言&#xff1a;傅里叶变换是Modulation, OFDM 技术的理论基础这里主要介绍连续性随机变量的傅里叶变换,以及对应的性质。https://zhuanlan.zhihu.com/p/339281545https://wenku.baidu.com/view/ab338e55a16925c52cc58bd63186bceb19e8ede4.html?_wkts_1672887094135https://w…

pdf如何防止被他人编辑

好多人一直在寻找研究如何编辑或者修改PDF文件&#xff0c;有需求就会有市场&#xff0c;现在市场上或者网络上有非常多的PDF编辑软件&#xff0c;可以编辑修改PDF文件中的内容。即使PDF文件加了密码保护&#xff0c;我们大部分人依然可以轻易的通过在浏览器中虚拟打印的方式&a…

2023.1.6 学习总结

1.set容器的相关函数 set&#xff0c;顾名思义是“集合”的意思&#xff0c;在set中元素都是唯一的&#xff0c;而且默认情况下会对元素自动进行升序排列。 set容器 包含头文件&#xff1a; #include<set> set中只能用insert函数实现数据的输入。 set<int> s…

32.深度学习模型优化加速方法-1

32.1 模型优化加速方法 模型优化加速能够提升网络的计算效率,具体包括: Op-level的快速算法:FFT Conv2d (7x7, 9x9), Winograd Conv2d (3x3, 5x5) 等;Layer-level的快速算法:Sparse-block net [1] 等;优化工具与库:TensorRT (Nvidia), Tensor Comprehension (Facebook) …

【代码题】栈的应用

目录 1.有效的括号 2.逆波兰表达式求值 1.有效的括号 点击进入该题 https://leetcode.cn/problems/valid-parentheses/description/ 给定一个只包括 (&#xff0c;)&#xff0c;{&#xff0c;}&#xff0c;[&#xff0c;] 的字符串 s &#xff0c;判断字符串是否有效。 有…

【黑马】瑞吉外卖-Day01、02笔记

瑞吉外卖 数据库搭建 表结构 Maven项目 创建Maven项目 编写pom文件 编写配置文件application.yml 创建启动类ReggieApplication.java 前端静态资源的配置 将两个前端静态资源包导入到resource目录下方&#xff0c;由于Spring-MVC默认只能访问static和templete下面的文件…

04-GC的常见收集方法:标记清除、标记复制、标记整理算法、分代收集的原理与特点?

1.标记清除算法(Mark-Sweep) 最基础的垃圾回收算法&#xff0c;分为两个阶段&#xff0c;标记和清除。 1.标记阶段标记出所有需要回收的对象 2.清除阶段回收被标记的对象所占用的空间 缺点: 1.容易产生大量的内存碎片,后续可能发生大对象不能找到可利用空间的问题 2.标记和清…

【JavaGuide面试总结】Java基础篇·上

【JavaGuide面试总结】Java基础篇上1.JVM vs JDK vs JRE2.Java 和 C 的区别?3.Java 程序从源代码到运行的过程4.为什么说 Java 语言“编译与解释并存”&#xff1f;5.说说default关键字的几个用法6.静态变量有什么作用&#xff1f;7.字符型常量和字符串常量的区别?8.成员变量…

Verilog语法笔记(夏宇闻第三版)-运算符及表达式

目录 运算符按其功能可分为以下几类: 按其所带操作数的个数运算符可分为三种&#xff1a; 基本的算术运算符&#xff1a; 位运算符&#xff1a; 逻辑运算符&#xff1a; 关系运算符&#xff1a; 等式运算符&#xff1a; 移位运算符&#xff1a; 位拼接运算符(Concatati…

png如何转pdf?这几个方法快收藏起来

现如今&#xff0c;电脑上拥有的图片格式那么多&#xff0c;而每种格式分别都有自己的特点&#xff0c;就例如png格式。它是一种无损压缩算法的图片格式&#xff0c;能够保证在不失真的情况下&#xff0c;压缩图片文件大小。但在我们工作中&#xff0c;难免会需要将png图片转换…

字典树基础与应用

字典树&#xff08;Trie) 字典树&#xff08;Trie&#xff09;也叫前缀树&#xff0c;是一种针对字符串进行维护的树。 其中的键通常是字符串&#xff0c;由节点在树中的位置决定&#xff0c;键保存在边而不是在节点 一个节点的所有子孙具有相同的前缀&#xff0c;也就是这个…

PLGA-MAL/COOH/NH2基团封端聚(D,L-丙交酯-co-乙交酯)共聚物;可以用于制备胶束或者囊泡等新型靶向材料

1. HO-PLGA-Mal 马来酰亚胺封端聚&#xff08;D&#xff0c;L-丙交酯-co-乙交酯&#xff09;共聚物中文名称 马来酰亚胺封端聚&#xff08;D&#xff0c;L-丙交酯-co-乙交酯&#xff09;共聚物英文名称 HO-PLGA-Mal分子量&#xff1a;1000-100000之间选择 比例&#xff08;LA…

Golang UDP IPV6 编程

一、网络通信的步骤 服务端 1.socket() 创建通信的套接字socket:ip:addr 2.bind() 将套接字绑定监听的地址和端口号&#xff0c;作用是&#xff1a;服务器一般有很多网卡&#xff0c;多个IP地址&#xff0c;bind指定具体监听 哪一个IP地址及对应的端口号&#xff08;若服务…

消防应急物资智能仓储管理系统

一&#xff0c;项目背景消防应急物资装备管理系统(智装备 DW-S302)是一套成熟系统&#xff0c;依托互 3D 技术、云计算、大数据、RFID 技术、数据库技术、AI、视频分析技术对 RFID 智能仓库进行统管理、分析的信息化、智能化、规范化的系统。基于物联网技术&#xff0c;实现装备…

win10录屏快捷键是什么?录屏快捷键怎么设置

录屏是我们在学习和工作&#xff0c;经常会使用得到的工具。不管是录制网课视频&#xff0c;还是录制线上办公会议&#xff0c;都可以使用得上。在win10电脑系统中&#xff0c;就有录屏的功能&#xff0c;还自带了录屏快捷键。那win10录屏快捷键是什么&#xff1f;今天就给大家…

通过SwitchyOmega插件实现Chrome的PAC模式代理网络连接

通过SwitchyOmega插件实现Chrome的PAC模式代理网络连接 文章目录通过SwitchyOmega插件实现Chrome的PAC模式代理网络连接SwitchyOmega的安装PAC脚本示例示例 1&#xff1a;如果主机是本地主机&#xff0c;则直接连接示例 2&#xff1a;如果主机在防火墙内部&#xff0c;则直接连…

华为云、阿里云、腾讯云、百度云、浪潮云、金山云-云计算能力横向对比

导读 近些年&#xff0c;各大公司和码农们对云服务需求日益增长&#xff0c;大家不断在问“做云服务和物联网服务器的到底哪家强&#xff1f;”。网上也有不少人给出简单的答案&#xff0c;“明显是腾讯云&#xff0c;华为云的应用还没那么广泛&#xff0c;目前最好的有三个&am…

SpringBoot统一功能处理实现

⭐️前言⭐️ 这篇文章主要介绍Spring Boot的统一功能处理模块&#xff0c;也是AOP的实战环节。 &#x1f349;欢迎点赞 &#x1f44d; 收藏 ⭐留言评论 &#x1f4dd;私信必回哟&#x1f601; &#x1f349;博主将持续更新学习记录收获&#xff0c;友友们有任何问题可以在评论…

ORB-SLAM2 --- KeyFrameDatabase::DetectLoopCandidates函数

目录 1.函数作用 2.函数流程 3.函数解析 3.1 传入参数解析 3.2 找出和当前帧具有公共单词的所有关键帧&#xff0c;不包括与当前帧连接的关键帧 3.3 统计上述所有闭环候选帧lKFsSharingWords中与当前帧具有共同单词最多的单词数&#xff0c;用来决定相对阈值 3.4 遍…

java基于ssm的图书管理系统图书借阅管理网站图书管理网站源码

简介 本项目是图书借阅管理系统&#xff0c;主要实现了对图书的管理和借阅。 演示视频 https://www.bilibili.com/video/BV14p4y1H7GQ/?share_sourcecopy_web&vd_sourceed0f04fbb713154db5cc611225d92156 技术 ssmjqueryajaxmysql 角色 管理员学生 功能 管理员&am…