vue 弹出框 引入另一个vue页面的示例代码

 更新时间:2023年08月23日 11:28:59   作者:taiguolaotu  
这篇文章主要介绍了vue 弹出框引入另一个vue页面,这种方式适用于在一个页面逻辑比较多的时候,可以搞多个页面,防止出错,本文通过示例代码给大家介绍的非常详细,需要的朋友可以参考下

为什么要这么做,适用于在一个页面逻辑比较多的时候,可以搞多个页面,防止出错

在这里插入图片描述

index页面点击解约按钮,弹出框 进入jieyue.vue

核心代码

在这里插入图片描述

 <el-button
            size="mini"
            type="text"
            icon="el-icon-edit"
            v-if="scope.row.delFlag == 0"
            @click="jieyue(scope.row)"
            v-hasPermi="['sep:channel:edit']"
          >解约</el-button>
    <testDialog title="测试窗口"  v-if="openDialog"  ref="testDialog"/>
  </div>
</template>
<script>
// 引用组件
import testDialog from "./jieyue.vue";
export default {
  // 注册组件
  components: {testDialog},
  name: "Channel",
  data() {
    return {
      openDialog: false,
    // 按钮方法
    jieyue() {
      this.openDialog = true;
      this.$nextTick(() => {
        this.$refs.testDialog.init(2);
      });
    },

代码截图

在这里插入图片描述

jieyue.vue就是常规代码了

<template>
  <!-- 添加或修改个体户渠道信息对话框 -->
  <el-dialog :title="title" :visible.sync="open" width="1000px" append-to-body :close-on-click-modal="false" :close-on-press-escape="false">
    <el-form ref="form" :model="form" :rules="rules" label-width="180px">
      <!--        <el-form-item label="渠道编号" prop="channelNo">
                <el-input v-model="form.channelNo" placeholder="请输入渠道编号" />
              </el-form-item>-->
      <el-form-item label="渠道商名称" prop="channelName">
        <el-input v-model="form.channelName" placeholder="请输入渠道商名称" />
      </el-form-item>
      <!-- 做成一个下拉框选择 -->
      <el-form-item label="上级渠道" prop="parentId">
        <!-- <el-input v-model="form.parentId" placeholder="请输入个体户父渠道ID" /> -->
        <el-select v-model="form.parentId" clearable placeholder="请选择上级渠道(无则不选)" >
          <el-option v-for="item in channelOption"
                     :key="item.id"
                     :label="item.channelName"
                     :value="item.id">
          </el-option>
        </el-select>
      </el-form-item>
      <el-form-item label="返佣收款公司名称" prop="channelRebateName" >
        <el-input v-model="form.channelRebateName" placeholder="请输入渠道返佣收款公司名称" />
      </el-form-item>
      <el-form-item label="返佣收款公司联系人" prop="channelLinkname">
        <el-input v-model="form.channelLinkname" placeholder="请输入渠道返佣收款公司联系人" />
      </el-form-item>
      <el-form-item label="返佣收款公司联系电话" prop="channelLinkphone" >
        <el-input v-model="form.channelLinkphone" placeholder="请输入渠道返佣收款公司联系电话" />
      </el-form-item>
      <el-form-item label="返佣收款公司联系邮箱" prop="channelLinkmail" >
        <el-input v-model="form.channelLinkmail" placeholder="请输入渠道返佣收款公司联系邮箱" />
      </el-form-item>
      <el-form-item label="返佣收款公司收款账户" prop="channelAccount" >
        <el-input v-model="form.channelAccount" placeholder="请输入渠道返佣收款公司收款账户" />
      </el-form-item>
      <el-form-item label="返佣收款公司开户银行" prop="channelBank" >
        <el-input v-model="form.channelBank" placeholder="请输入渠道返佣收款公司开户银行" />
      </el-form-item>
      <el-form-item label="返佣打款服务商名称"  prop="serviceId">
        <el-select v-model="form.serviceId" placeholder="请选择返佣打款服务商名称" @change="chooseService($event)">
          <el-option
            v-for="item in servicesOptions"
            :key="item.id"
            :label="item.serviceName"
            :value="item.id"
          ></el-option>
        </el-select>
      </el-form-item>
      <el-form-item label="客户经理"  prop="salesManagerId">
        <el-select v-model="form.salesManagerId" placeholder="请选择客户经理" @change="chooseManager($event)">
          <el-option
            v-for="item in managerOptions"
            :key="item.id"
            :label="item.name"
            :value="item.id"
          ></el-option>
        </el-select>
      </el-form-item>
    </el-form>
    <div slot="footer" class="dialog-footer">
      <el-button type="primary" @click="submitForm">确 定</el-button>
      <el-button @click="cancel">取 消</el-button>
    </div>
  </el-dialog>
</template>
<script>
import {
  listChannel, getChannel, delChannel, addChannel, updateChannel,
  deactivateAccount,
  resetPassword,
  getChannelSelection,
  updateChannelBatch, addChannelUser, listChannelData
} from '@/api/sep/channel'
import { getSepEnterprise, updateSepEnterpriseData } from '@/api/sep/SepEnterprise'
import { listUser,changeUserStatus } from '@/api/system/user'
export default {
  name: "testDialog",
  data() {
    return {
      form: {},
      //服务商list
      servicesOptions:[],
      //客户经理list
      managerOptions:[],
      channelOption:[],
      // 表单校验
      rules: {
        salesManagerId:[{ required: true, message: '客户经理不能为空', trigger: 'change' }],
        serviceId:[{ required: true, message: '返佣打款服务商名称不能为空', trigger: 'change' }],
        channelBank:[{ required: true, message: '返佣收款公司开户银行不能为空', trigger: 'blur' }],
        channelName:[{ required: true, message: '渠道商名称不能为空', trigger: 'blur' }],
        channelRebateName:[{ required: true, message: '返佣收款公司名称不能为空', trigger: 'blur' }],
        channelLinkname:[{ required: true, message: '联系人不能为空', trigger: 'blur' }],
        channelLinkmail:[{ required: true, message: '联系邮箱不能为空', trigger: 'blur' }],
        channelLinkphone: [
          // 添加正则表达式 pattern: /^1[3|5|7|8|9]\d{9}$/,验证手机号是否正确
          { required: true, message: '请输入手机号', trigger: 'blur' },
          // { pattern: /^1[3|5|7|8|9]\d{9}$/, message: '请输入正确的号码格式', trigger: 'change' }
        ],
        channelAccount: [
          { required: true, message: '请输入银行卡号', trigger: 'blur' },
          // {pattern: /^([1-9])(\d{17})(\d|X)$/,message: "请输入正确的银行卡号",trigger: "change"}
        ],
      },
      // 弹出层标题
      title: "",
      // 是否显示弹出层
      open: false,
      // 表单参数
      bizform: {}
    };
  },
  methods: {
    // 窗口初始化方法,nextTick方法可以添加逻辑,如打开窗口时查询数据填充
    init(bizId) {
      console.log("123")
      this.open = true;
      // this.$nextTick(() => {
      //   getById(bizId).then(response => {
      //     this.bizform = response.data;
      //     this.open = true;
      //     this.title = "修改业务";
      //   });
      // });
    },
    // 取消按钮
    cancel() {
      this.open = false;
      this.reset();
    },
    submitForm: function () {
      this.$refs["bizform"].validate(valid => {
        if (valid) {
          if (this.bizform.id != undefined) {
            updateBizDefine(this.bizform).then(response => {
              if (response.data) {
                this.msgSuccess("修改成功");
                this.open = false;
                // 调用主页面的getList方法刷新主页面
                this.$parent.getList();
              } else {
                this.msgError(response.resultMsg);
              }
            });
          } else {
            addBizDefine(this.bizform).then(response => {
              if (response.data) {
                this.msgSuccess("新增成功");
                this.open = false;
                // 调用主页面的getList方法刷新主页面
                this.$parent.getList();
              } else {
                this.msgError(response.resultMsg);
              }
            });
          }
        }
      });
    }
  }
};
</script>

参考资料:https://www.ibashu.cn/news/show_306835.html

到此这篇关于vue 弹出框 引入另一个vue页面的文章就介绍到这了,更多相关vue 弹出框 另一个vue页面内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vue封装一个简单轻量的上传文件组件的示例

    Vue封装一个简单轻量的上传文件组件的示例

    这篇文章主要介绍了Vue封装一个简单轻量的上传文件组件的示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-03-03
  • nuxt.js添加环境变量,区分项目打包环境操作

    nuxt.js添加环境变量,区分项目打包环境操作

    这篇文章主要介绍了nuxt.js添加环境变量,区分项目打包环境操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • vue封装swiper代码实例解析

    vue封装swiper代码实例解析

    这篇文章主要介绍了vue封装swiper代码实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-10-10
  • vue-router重定向和路由别名的使用讲解

    vue-router重定向和路由别名的使用讲解

    今天小编就为大家分享一篇关于vue-router重定向和路由别名的使用讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • vue两个输入框联动校验方式(最大值-最小值)

    vue两个输入框联动校验方式(最大值-最小值)

    这篇文章主要介绍了vue两个输入框联动校验方式(最大值-最小值),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • Vue.js 的过滤器你了解多少

    Vue.js 的过滤器你了解多少

    这篇文章主要为大家详细介绍了Vue.js 的过滤器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • Vue中Axios中取消请求及阻止重复请求的方法

    Vue中Axios中取消请求及阻止重复请求的方法

    为了防止用户在网络不好或者其他情况下短时间内重复进行接口请求,重复发送多次请求,本文主要介绍了Vue中Axios中取消请求及阻止重复请求的方法,感兴趣的可以了解一下
    2022-02-02
  • vue diff算法全解析

    vue diff算法全解析

    这篇文章主要介绍了vue diff算法的使用,帮助大家更好的理解和学习使用vue,感兴趣的朋友可以了解下
    2021-04-04
  • 浅谈Vue.js中的v-on(事件处理)

    浅谈Vue.js中的v-on(事件处理)

    本篇文章主要介绍了Vue.js中的v-on(事件处理),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-09-09
  • vue-cli+webpack记事本项目创建

    vue-cli+webpack记事本项目创建

    这篇文章主要为大家详细介绍了vue-cli+webpack创建记事本项目,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-04-04

最新评论