最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

vue综合组件通信使用案例

来源:动视网 责编:小OO 时间:2020-11-27 19:54:49
文档

vue综合组件通信使用案例

本文实例为大家分享了vue综合组件间的通信,供大家参考,具体内容如下:实现一个ToDoList。①完成所有的组件的创建和使用。②add;点击add按钮时候,将用户输入的内容(todoinput),显示在(todolist)。核心代码:兄弟组件间通信。步骤1:var bus = new Vue()。步骤2:在准备接受数据的组件。bus.$on(';addEvent';,function(){})。步骤3:触发事件;bus.$emit(';addEvent';,123)。将todolist中数组的元素 渲染在todoitem的每一个span标签。(父子组件通信)。③delete;
推荐度:
导读本文实例为大家分享了vue综合组件间的通信,供大家参考,具体内容如下:实现一个ToDoList。①完成所有的组件的创建和使用。②add;点击add按钮时候,将用户输入的内容(todoinput),显示在(todolist)。核心代码:兄弟组件间通信。步骤1:var bus = new Vue()。步骤2:在准备接受数据的组件。bus.$on(';addEvent';,function(){})。步骤3:触发事件;bus.$emit(';addEvent';,123)。将todolist中数组的元素 渲染在todoitem的每一个span标签。(父子组件通信)。③delete;


这次给大家带来vue综合组件通信使用案例,vue综合组件通信使用的注意事项有哪些,下面就是实战案例,一起来看一下。

本文实例为大家分享了vue综合组件间的通信,供大家参考,具体内容如下

实现一个ToDoList。

①完成所有的组件的创建和使用

②add

点击add按钮时候,将用户输入的内容(todoinput),显示在(todolist)

核心代码:兄弟组件间通信
步骤1:var bus = new Vue()
步骤2:在准备接受数据的组件

bus.$on('addEvent',function(){
})

步骤3:触发事件

bus.$emit('addEvent',123)

将todolist中数组的元素 渲染在todoitem的每一个span标签。(父子组件通信)

③delete

在todoitem中点击delete按钮时,将该todoitem删除,由于todoitem的数量 取决于 todolist中数组

子组件 和 父组件通信:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Title</title>
 <script src="js/vue.js"></script>
 <script src="js/vue-resource.js"></script>
</head>
<body>
<p id="container">
 <p>{{msg}}</p>
 <todobox></todobox>
</p>
<script>
 <!--兄弟间通信-->
 var bus = new Vue();
// input组件
 Vue.component("todoinput",{
// 保存用户输入的数据
 data:function(){
 return{
 userInput:""
 }
 },
 methods:{
 sendInput:function(){
// 触发自定义事件,将this.userInput这个传递到todolist
 bus.$emit("addEvent",this.userInput);
 this.userInput = "";
 }
 },
 template: `
 <p>
 <h1>待做事项</h1>
 <input type="text" placeholder="健身" v-model="userInput"/>
 <button @click="sendInput">Add</button>
 </p>
 `
 })
// 列表组件
 Vue.component("todolist",{
// 保存传递来的用户输入的数据
 data:function(){
 return{
 inputList:[]
 }
 },
 beforeMount:function(){
// 触发绑定
// msg就是事件触发后传递过来的数据
 //var that = this;
 bus.$on("addEvent",(msg)=>{
// 保存到数组inputList中
 this.inputList.push (msg) ;
 })
 },
 template: `
 <p>
 <ul>
 <todoitem v-bind:content="tmp" v-for="(tmp,index) in inputList" v-bind:key="index" v-bind:myIndex="index"></todoitem>
 </ul>
 </p>
 `
// 出现警告,加下标,提高列表渲染
 })
// item组件
 Vue.component("todoitem",{
// props子组件获取父组件的数据,将todolist中的内容以及内容的下标获取
 props:["content","myIndex"],
 methods:{
// 通过下标删除
 deleteList:function(){
 this.$parent.inputList.splice(this.myIndex,1);
 }
 },
 template: `
 <p>
 <li>
 <button @click="deleteList">delete</button>
 <span>{{content}}</span>
 </li>
 </p>
 `
 })
//根组件
 Vue.component("todobox",{
 template:`
 <p>
 <todoinput></todoinput>
 <todolist></todolist>
 </p>
 `
 })
 new Vue({
 el: "#container",
 data: {
 msg: "Hello Vue"
 }
 })
</script>
</body>
</html>

相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

文档

vue综合组件通信使用案例

本文实例为大家分享了vue综合组件间的通信,供大家参考,具体内容如下:实现一个ToDoList。①完成所有的组件的创建和使用。②add;点击add按钮时候,将用户输入的内容(todoinput),显示在(todolist)。核心代码:兄弟组件间通信。步骤1:var bus = new Vue()。步骤2:在准备接受数据的组件。bus.$on(';addEvent';,function(){})。步骤3:触发事件;bus.$emit(';addEvent';,123)。将todolist中数组的元素 渲染在todoitem的每一个span标签。(父子组件通信)。③delete;
推荐度:
标签: VUE 例子 案例
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top