element-ui 的select下拉选择框,当切换选项时触发事件弹出提示框,点击确认切换,取消则不改变数据

需求

select下拉选择框有一个默认选中的初始值,当我们切换选择的值时,弹出提示框,弹框包含取消和继续按钮,提示信息为:改变选择的值XXXXX,是否继续?

点击继续 选中的值改变

点击取消 则保持之前选中的值不变

代码

大体思路就是要保存一份前一次选中的值,切换值后,弹出提示框,当确认时,发送请求改变数据,否则,将值赋为之前选中的那个值。

<template>
  <div>
    <el-select v-model="storeLocation" placeholder="请选择">
      <el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value"></el-option>
    </el-select>
    <el-dialog
      :visible.sync="changeStoreVisible"
      class="taskDialog delete-shortcut-dialog"
      width="420px"
      :modal="false"
      :show-close="false"
      :close-on-click-modal="false"
    >
      <template slot="title">
        <span style="font-size:16px;font-weight:400;">
          <i
            class="iconfont icon-warning"
            style="font-size:20px;color:rgba(23,155,255,1);margin-right:5px;"
          ></i>是否改变选项值
        </span>
      </template>
      <p class="tips-text" style="height: 38px;">
        <span style="color:red;font-size:14px;">改变选项值,</span>是否继续?
      </p>
      <div slot="footer" class="dialog-footer">
        <el-button @click="changeStoreCancle">取 消</el-button>
        <el-button type="primary" @click="changeStoreForm">确 定</el-button>
      </div>
    </el-dialog>
  </div>
</template>

<script>
export default {
  data() {
    return {
      options: [
        {
          value: '选项1',
          label: '黄金糕'
        },
        {
          value: '选项2',
          label: '双皮奶'
        },
        {
          value: '选项3',
          label: '蚵仔煎'
        },
        {
          value: '选项4',
          label: '龙须面'
        },
        {
          value: '选项5',
          label: '北京烤鸭'
        }
      ],
      storeLocation: '初始值',
      changeStoreVisible: false,
      beforeStorageValue: '',
      afterStorageValue: ''
    }
  },
  watch: {
    storeLocation: {
      immediate: true,
      handler(val, old) {
        console.log('val:', val, 'old:', old)
        if (this.beforeStorageValue) {
          console.log(
            'val:',
            val,
            'old:',
            old,
            'this.beforeStorageValue',
            this.beforeStorageValue
          )
          if (val !== this.beforeStorageValue) {
            this.changeStoreVisible = true
          }
        }
      }
    }
  },
  methods: {
    changeStoreCancle() {
      this.storeLocation = this.beforeStorageValue
      this.changeStoreVisible = false
    },
    changeStoreForm() {
      this.changeStoreVisible = false
    }
  },
  mounted() {
    this.beforeStorageValue = this.storeLocation
  }
}
</script>
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 把目标变成一件件小事,做就对了! 把一件事情分解成每天要做的事情。然后一件一件的去完成。 1、恰当地和别人相处,让...
    文H阅读 154评论 13 7
  • 昨天周三,早上九点多就醒了,但是没起来,一直到十一点多,表弟叫我才起来的,起来以后爷爷也在,是来接表弟回去的,但是...
    坚志阅读 100评论 0 0
  • 1. 官场小说人物传记,历史小说这些都可以看,走进别人的人生,从里面理解知道官场百态,知道那些渠渠道道,活跃自己的...
    智囊团阅读 131评论 0 0
  • 如果你是叶间的苹果 我要做夏日的凉风 这样 我不用再担心会够不到你 而且 我可以时时刻刻陪在你身边
    辛安小阅读 719评论 37 62