vue helloworld.vue 点击按钮弹出 dialog,并给dialog传值

1 DataAnalysisVue.Vue -->应该组件文件名和 name: 的名字一致

javascript 复制代码
<template>
  <div>
    <el-dialog :title="dataAnalysisMsg" :visible.sync="dataAnalysisvalue" :before-close="handleClose">
      <span>{{ dataAnalysisMsg }}</span>
      <span slot="footer" class="dialog-footer">
        <el-button @click="dataAnalysisvalue= false">取 消</el-button>
        <el-button type="primary" @click="dataAnalysisvalue = false">确 定</el-button>
      </span>
    </el-dialog>
  </div>
</template>

<script>

export default {
  name: 'DataAnalysisVue',
  data() {

    return {

      dataAnalysisvalue: false,
      dataAnalysisMsg: '', // 新增 warningVueMessage 字段
    }
  },
  methods: {
    handleClose(done) {
      this.$confirm('确认关闭?')
        .then(_ => {
          // 关闭方法-上方传的参数done
          done();
        })
        .catch(_ => { });
    },
  },
}


</script>

2 helloworld.vue 添加dialog.vue组件

javascript 复制代码
<template>
  <div>
    <button @click="dataAnalysis('这是数据分析的内容')">数据分析</button>
    <DataAnalysisVue ref="dialogDataAnalysis"></DataAnalysisVue>
  </div>
</template>

<script>
import DataAnalysisVue from './DataAnalysisVue'

export default {
  components: {
    DataAnalysisVue
  },
  methods: {
    dataAnalysis(msg) {
      this.$refs.dialogDataAnalysis.dataAnalysisMsg = msg // 给指定组件的变量赋值
      this.$refs.dialogDataAnalysis.dataAnalysisvalue = true
    },
  }
}
</script>

3 分析helloworld.vue

3.1 导入组件

javascript 复制代码
import DataAnalysisVue from './DataAnalysisVue'

3.2 声明组件

javascript 复制代码
components: {
    DataAnalysisVue
  },

3.3 插入组件 并给组件 命名 ref

javascript 复制代码
<DataAnalysisVue ref="dialogDataAnalysis"></DataAnalysisVue>

3.4 做按钮

javascript 复制代码
 <button @click="dataAnalysis('这是数据分析的内容')">数据分析</button>

3.5 做按钮方法 点击后给指定的组件ref中的变量赋值

javascript 复制代码
dataAnalysis(msg) {
      this.$refs.dialogDataAnalysis.dataAnalysisMsg = msg // 给指定组件的变量赋值
      this.$refs.dialogDataAnalysis.dataAnalysisvalue = true
    },

4 分析 DataAnalysisVue.Vue

4.1 让标题等于 传来的值

javascript 复制代码
<el-dialog :title="dataAnalysisMsg"

4.2 :visible.sync="dataAnalysisvalue"-->DataAnalysisVue.Vue和helloworld.vue值双向绑定

javascript 复制代码
:visible.sync 是 Vue 组件传递数据的一种方式,它是实现双向绑定的一种简写语法。
在这个例子中,.sync 会添加一个名为 update:visible 的监听器,
并且会使 visible 的值变为内部更新所传递的值。
也就是说,:visible.sync 的作用是实现 visible 的值在组件内外的双向绑定。

举个例子,如果我们把 dataAnalysisvalue 的值从组件内部改变为 true,
那么它也会被同步更新到组件外部的 dataAnalysisvalue。
同样地,如果我们从组件外部改变了 dataAnalysisvalue 的值,
那么它也会被同步更新到组件内部的 visible。

因此,在这个例子中,:visible.sync="dataAnalysisvalue" 的作用就是使得 visible 的值和 dataAnalysisvalue 的值保持同步,实现双向数据绑定。
相关推荐
漫天黄叶远飞1 分钟前
async/await 到底怎么工作的?
前端
ai_xiaogui10 分钟前
PanelAI前端全面升级!私有化部署AI面板控制台+生态市场一键管理详解
前端·人工智能·comfyui一键部署·生态市场算力共享·ai面板控制台·panelai私有化部署·大模型前端管理
Jelena1577958579212 分钟前
1688.item_get_app接口:包装尺寸重量信息深度解析
开发语言·前端·python
酉鬼女又兒20 分钟前
零基础快速入门前端DOM核心知识点详解与蓝桥杯Web赛道备考指南(可用于备赛蓝桥杯Web应用开发)
前端·职场和发展·蓝桥杯
daols8826 分钟前
vue甘特图vxe-gantt实现点击任务条弹出编辑表单
前端·vue.js·甘特图·vxe-gantt
zfyljx28 分钟前
Taro+react input框在文字中间插入光标会跳到末尾问题
javascript·react.js·taro
Fairy要carry29 分钟前
项目05-手搓Agent之任务通信+任务编排的实现
服务器·前端·网络
忘忧记29 分钟前
pytest进阶参数化用法
前端·python·pytest
予你@。42 分钟前
vue 使用html2canvas + jsPDF 将html导出为pdf (延伸问题)
vue.js·pdf·html
github_czy44 分钟前
FastAPI 流式响应核心原理解析(含前端断开感知)
前端·fastapi