最新文章专题视频专题问答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
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

Vuejs 实现简易 todoList 功能 与 组件实例代码

来源:懂视网 责编:小采 时间:2020-11-27 22:08:00
文档

Vuejs 实现简易 todoList 功能 与 组件实例代码

Vuejs 实现简易 todoList 功能 与 组件实例代码:todoList 结合之前 Vuejs 基础与语法 •使用 v-model 双向绑定 input 输入内容与数据 data •使用 @click 和 methods 关联事件 •使用 v-for 进行数据循环展示 <!DOCTYPE html> <html lang=
推荐度:
导读Vuejs 实现简易 todoList 功能 与 组件实例代码:todoList 结合之前 Vuejs 基础与语法 •使用 v-model 双向绑定 input 输入内容与数据 data •使用 @click 和 methods 关联事件 •使用 v-for 进行数据循环展示 <!DOCTYPE html> <html lang=

todoList

结合之前 Vuejs 基础与语法
•使用 v-model 双向绑定 input 输入内容与数据 data
•使用 @click 和 methods 关联事件
•使用 v-for 进行数据循环展示

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>TodoList</title>
 <script src="./vue.js"></script>
</head>
<body>
 <div id="root">
 <div>
 <input v-model="inputValue"/>
 <button @click="handleSubmit">提交</button>
 </div>
 <ul>
 <li v-for="(item,index) of list" :key="index">
 {{item}}
 </li>
 </ul>
 </div>
 <script>
 new Vue({
 el: "#root",
 data: {
 inputValue: '',
 list: []
 },
 methods: {
 handleSubmit: function(){
 this.list.push(this.inputValue)
 this.inputValue = ''
 }
 }
 })
 </script>
</body>
</html>

JSbin 预览

todoList 组件拆分

Vuejs 组件相关 详细参考组件基础

全局组件

注册全局组件,并在 HTML 中通过模板调用组件

//注册全局组件
 Vue.component('todo-item',{
 template: '<li>item</li>'
 })
 <ul>
 <!-- <li v-for="(item,index) of list" :key="index">
 {{item}}
 </li> -->
 <todo-item></todo-item> <!-- 通过模板使用组件 -->
 </ul>

JSbin 预览

局部组件

在注册了局部组件之后,直接通过模板调用是不可以的,必须要在最外层的 Vue 的实例中添加 components: { }进行组件声明。 

//注册局部组件
 var TodoItem = {
 template: '<li>item</li>'
 }
 new Vue({
 el: "#root",
 components: { //局部组件需要声明的 components
 'todo-item': TodoItem
 },
 data: {
 inputValue: '',
 list: []
 },
 methods: {
 handleSubmit: function(){
 this.list.push(this.inputValue)
 this.inputValue = ''
 }
 }
 })

JSbin 预览

即通过局部注册的组件,需要在其他的 Vue 实例中使用该局部组件。必须使用 components 对该局部组件进行注册。
上面的实例中,要在 Vue 实例中使用 TodoItem 这个局部组件,就通过 todo-item 这个标签来使用。当在实例中 注册好了以后,才可以在模板里面使用这个标签。这样就算正确的使用了局部组件。

外部传递参数

给 todo-item 标签添加 :content 属性,值为循环的每一项的内容 "item",

这样就可以吧 content 传递给 todo-item 这个组件

<todo-item v-for="(item,index) of list" :key="index" :content="item"></todo-item>

但是直接将组件改成是不行的

 Vue.component('todo-item',{
 template: '<li>{{content}}</li>'
 })

需要让组件接收属性,所以要在todo-item组件里面定义props属性,其值为一个数组 'content' 。
其含义是,该组件接收从外部传递的进来的名字叫做 content 的属性

 Vue.component('todo-item',{
 props: ['content'],
 template: '<li>{{content}}</li>'
 })

JSbin 预览

组件与实例的关系

Vue 之中,每一个组件其实也是一个 Vue 的实例。因此在 Vue 项目中,是一个个实例构建而成的。
因此组件之中,也可以绑定 @click 事件,添加 methods 属性。

 Vue.component('todo-item',{
 props: ['content'],
 template: '<li @click="handleClick">{{content}}</li>',
 methods: {
 handleClick: function(){
 alert('clicked')
 }
 }
 })

JSbin 预览

同样的实例也可以被称作一个组件,那么我们这个根实例当中的 template 模板是什么呢 ?
如果一个 Vue 实例没有模板,会到挂载点去找。如下实例,根实例会找到 #root 下面挂载点的所有内容作为模板。

new Vue({
 el: "#root",
 data: {
 inputValue: '',
 list: []
 },
 methods: {
 handleSubmit: function(){
 this.list.push(this.inputValue)
 this.inputValue = ''
 }
 }
 })

为 todoList 添加删除功能

通过 发布 / 订阅,当子组件点击时,通知父组件把数据删除掉。在子组件中,发布自定义一个 'delete' 事件。调用 this.$emit 方法,并传递 index 的值。

子组件向外部进行发布

 //子组件
 Vue.component('todo-item',{
 props: ['content','index'],
 template: '<li @click="handleClick">{{content}}</li>',
 methods: {
 handleClick: function(){
 //发布
 this.$emit('delete', this.index)
 }
 }
 })

父组件在模板里创建子组件的时候,监听子组件向外触发的 delete 事件,如果监听到 delete 事件,执行 handleDelete 函数。

 <todo-item v-for="(item,index) of list"
 :key="index"
 :content="item"
 :index="index"
 @delete="handleDelete"> <!-- 监听delete事件 -->
 </todo-item> <!-- 通过模板使用组件 -->

然后在父组件的 methods 中,写好 handleDelete 方法。

 //最外层实例,父组件
 new Vue({
 el: "#root",
 data: {
 inputValue: '',
 list: []
 },
 methods: {
 handleSubmit: function(){
 this.list.push(this.inputValue)
 this.inputValue = ''
 },
 handleDelete: function(index){
 this.list.splice(index,1) //使用splice方法删除list
 }
 }
 })

总结

以上所述是小编给大家介绍的Vuejs 实现简易 todoList 功能 与 组件,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

Vuejs 实现简易 todoList 功能 与 组件实例代码

Vuejs 实现简易 todoList 功能 与 组件实例代码:todoList 结合之前 Vuejs 基础与语法 •使用 v-model 双向绑定 input 输入内容与数据 data •使用 @click 和 methods 关联事件 •使用 v-for 进行数据循环展示 <!DOCTYPE html> <html lang=
推荐度:
标签: 功能 VUE js
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top