(vue基础试炼_04)使用组件改造TodoList

接上一篇:(vue基础试炼_03)使用vue.js实现TodoListhttps://gblfy.blog.csdn.net/article/details/103842233

指令说明
v-bind传入绑定值

在这里插入图片描述

文章目录

  • 一、前端页面组件化
  • 二、全局组件学习
  • 三、局部组件学习

一、前端页面组件化

页面组件化:
简单理解就是一个页面可以划分成几个区域,一个区域就可以看作是一个组件,那整个页面就相当于有很多组件拼接而成的,就像拼积木一样,这样,每个组件是细致的,也是容易维护的。

在TodoList例子中,列表就可以看作是一个组件。

以前列表项是通过li标签来显示的

<li v-for="item in list">{{item}}</li>

二、全局组件学习

下面把li标签中的内容整体变成一个组件
在script标签里面,我们调用一个Vue.component全局组件,在组件中定义模板和我们需要接收的参数的值,通过插值表达式渲染到页面进行展示
在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>使用组件改造TodoList</title><!--引入vue.js库--><script src="vue.js"></script>
</head><body>
<!--vue接管的div-->
<div id="app"><div><input type="text" v-model="inputValue"><button v-on:click="handleBtnClick">提交</button></div><ul><todo-item v-bind:content="item"v-for="item in list"></todo-item></ul>
</div><script>Vue.component("TodoItem", {props: ['content'],template: "<li>{{content}}</li>"});/*创建了一个vue实例*/var app = new Vue({el: '#app',data: {list: [],inputValue: ''},methods: {handleBtnClick: function () {this.list.push(this.inputValue)this.inputValue = ''}}});
</script>
</body>
</html>

在这里插入图片描述
在这里插入图片描述
我们把list循环出的每一个值都赋值给item,然后,再把item通过v-bind指令传给todo-item标签,怎么传呢?通过content这个变量来传递。
子组件(todo-item)传递值给父组件,那父组件如何接收呢?
在父组件中添加 props: ['content'],来接收子组件传递过来的参数内容。
在这里插入图片描述
这样的话子组件中就可以接收外部传递过来content参数值,而content的值就是item,而item就是list通过循环出来的每一项,所以,子组件就接收到了list数组中的每一项的值item。
子组件接收到的content值,需要在模板(template)li标签中通过插值表达式,渲染出来展示到页面中。

梳理逻辑:
首先我定义了一个组件叫TodoItem,然后呢,这是一个全局的组件,直接可以在我们的模板中使用这个组件todo-item,怎样使用这个组件呢?
我们通过list来决定到底循环多少个todo-item这个组件,同时,把每一个list的每一项的内容,通过v-bind的语法借助content这个变量,擦混递给了todo-item这个组件,而如果你想使用父组件传递过来的数据,需要在props中对content进行接收,接收完成后,我们的模板中用到了content,然后组件就会将这个content渲染出来。

三、局部组件学习

使用局部组件实现上面案例

序号说明
创建一个局部组件
将局部组件以对象的形式在Vue实例的components里面进行注册即可

在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>使用组件改造TodoList</title><!--引入vue.js库--><script src="vue.js"></script>
</head><body>
<!--vue接管的div-->
<div id="app"><div><input type="text" v-model="inputValue"><button v-on:click="handleBtnClick">提交</button></div><ul><todo-item v-bind:content="item"v-for="item in list"></todo-item></ul>
</div><script>/*创建一个局部组件 TodoItem*/var TodoItem = {props: ['content'],template: "<li>{{content}}</li>"}/*创建了一个vue实例*/var app = new Vue({el: '#app',/*通过对象来注册局部组件TodoItem*/components: {TodoItem: TodoItem},data: {list: [],inputValue: ''},methods: {handleBtnClick: function () {this.list.push(this.inputValue)this.inputValue = ''}}});
</script>
</body>
</html>

下一篇:(vue基础试炼_05)简单组件之间的传值https://blog.csdn.net/weixin_40816738/article/details/103845363

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/521871.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

我们到底该如何看待6G?

戳蓝字“CSDN云计算”关注我们哦&#xff01;近日&#xff0c;加拿大媒体报道&#xff0c;华为已确认在加拿大渥太华开启6G网络研究&#xff0c;已与加拿大多所大学的研究者展开洽谈。华为表示&#xff0c;自家的渥太华研发实验室将引领华为全球6G发展。图片来源网络消息传出之…

两年AI研究经验(教训)总结,进来看看吧!

摘要&#xff1a; 本文以过来人的身份将自身2年的研究经验做了一下分享&#xff0c;希望本文对于即将开始从事人工智能研究的朋友有所帮助。人工智能研究这个领域是有一定门槛的。对于初学者来说&#xff0c;一般通常的做法是直接购买一些热门的书籍&#xff0c;比如“西瓜书”…

C语言:字符串字面量及其保存位置

相关阅读 C语言https://blog.csdn.net/weixin_45791458/category_12423166.html?spm1001.2014.3001.5482 虽然C语言中不存在字符串类型&#xff0c;但依然可以通过数组或指针的方式保存字符串&#xff0c;但字符串字面量却没有想象的这么简单&#xff0c;本文就将对此进行讨论…

system.argumentnullexception值不能为null_MySQL NULL 值如何处理?

我们已经知道 MySQL 使用 SQL SELECT 命令及 WHERE 子句来读取数据表中的数据,但是当提供的查询条件字段为 NULL 时&#xff0c;该命令可能就无法正常工作。为了处理这种情况&#xff0c;MySQL提供了三大运算符:IS NULL: 当列的值是 NULL,此运算符返回 true。IS NOT NULL: 当列…

神经网络的优缺点

摘要&#xff1a; 深度学习目前受到了追捧。人们想将神经网络应用到各个地方&#xff0c;但是它们真的适合每个地方吗&#xff1f;在本篇文章中&#xff0c;将对于这个问题以及深度学习现在如此受追捧的原因进行讨论。通过这篇文章&#xff0c;您将了解神经网络的主要缺点&…

(vue基础试炼_05)简单组件之间的传值

接上一篇&#xff1a;&#xff08;vue基础试炼_04&#xff09;使用组件改造TodoListhttps://gblfy.blog.csdn.net/article/details/103844256 文章目录一、上篇回顾① 代码欣赏② 代码分析二、子组件如何向父组件传值呢&#xff1f;① 需求案例文档② 需求案例效果图③ 思考与思…

漫画:程序员战力图鉴

戳蓝字“CSDN云计算”关注我们哦&#xff01;看漫画了解程序员战斗力 are u ready&#xff1f;编程架构能力撕比嘴炮能力划水摸鱼能力花式甩锅能力画饼忽悠能力PPT吹比能力哈哈哈哈哈哈程序员哥哥上面说的是你吗 福利扫描添加小编微信&#xff0c;备注“姓名公司职位”&#xf…

Python数据挖掘与机器学习,快速掌握聚类算法和关联分析

摘要&#xff1a;前文数据挖掘与机器学习技术入门实战与大家分享了分类算法&#xff0c;在本文中将为大家介绍聚类算法和关联分析问题。分类算法与聚类到底有何区别&#xff1f;聚类方法应在怎样的场景下使用&#xff1f;如何使用关联分析算法解决个性化推荐问题&#xff1f;本…

评分9.7!这本Python书彻底玩大了?程序员:真香!

「超级星推官/每周分享」是一个围绕程序员生活、学习相关的推荐栏目。CSDN出品&#xff0c;每周发布&#xff0c;暂定5期。关键词&#xff1a;靠谱&#xff01;优质&#xff01;本期内容&#xff0c;我们将抽1人送出由我司程序员奉为“超级神作”的《疯狂Python讲义》1本&#…

vs 如何将源文件转换成可执行文件_如何将手机便签转换成word文本文档

如何将手机便签转换成word文本文档&#xff1f;实际上&#xff0c;很多手机自带的便签&#xff0c;虽然可以将单条便签内容&#xff0c;以文字或者图片的形式分享到xxx云文档&#xff0c;但却很少有支持直接转换成Word文档的。一般情况下&#xff0c;他们需要将手机便签里的内容…

端上智能——深度学习模型压缩与加速

摘要&#xff1a;随着深度学习网络规模的增大&#xff0c;计算复杂度随之增高&#xff0c;严重限制了其在手机等智能设备上的应用。如何使用深度学习来对模型进行压缩和加速&#xff0c;并且保持几乎一样的精度&#xff1f;本文将为大家详细介绍两种模型压缩算法&#xff0c;并…

jvm调优 java_opt_Java-100天知识进阶-JVM调优工具-JDK自带工具-知识铺《八》

原标题&#xff1a;Java-100天知识进阶-JVM调优工具-JDK自带工具-知识铺《八》JVM 监控分析工具一、JDK 自带工具1. jconsoleJDK/bin 目录下&#xff0c; jconsole.exe 双击打开&#xff0c; 自动搜索本机运行的虚拟机进程。选择其中一个进程即可&#xff0c;开始进行JVM监控1.…

这帮吃货程序猿,给阿里食堂来了一波骚操作

我叫宋爽&#xff0c;在别人眼里&#xff0c;我是一个程序猿。 别的程序猿&#xff0c;喜欢摁键盘&#xff0c;我嘛&#xff0c;就喜欢吃。 有一次&#xff0c;去医院体检&#xff0c;拿到CT片的我&#xff0c;看着自己的脊椎骨&#xff0c;脑子中一直在想&#xff1a;啊&#…

linux 查看shell脚本执行了多长时间

步骤说明命令①写一个1.sh脚本vim1.sh&#xff0c;把脚本内容复制进去②赋予1.sh可执行权限chmod u_x 1.sh③把要执行的命令复制到第4行&#xff0c;保存退出esc :wq④执行脚本./1sh⑤查看执行脚本&#xff0c;共消耗多长时间基础脚本模板 #!/bin/bash starttimedate %Y-%m-%d…

任正非表示华为可以向美国企业转让5G技术;谷歌同意支付5亿欧元买断与法国纠纷;京东公布iPhone11系列预售战报……...

关注并标星星CSDN云计算极客头条&#xff1a;速递、最新、绝对有料。这里有企业新动、这里有业界要闻&#xff0c;打起十二分精神&#xff0c;紧跟fashion你可以的&#xff01;每周三次&#xff0c;打卡即read更快、更全了解泛云圈精彩newsgo go go 联想举办YOGA 2019秋季新品品…

Tensorflow快餐教程(1) - 30行代码搞定手写识别

摘要&#xff1a; Tensorflow入门教程1去年买了几本讲tensorflow的书&#xff0c;结果今年看的时候发现有些样例代码所用的API已经过时了。看来自己维护一个保持更新的Tensorflow的教程还是有意义的。这是写这一系列的初心。快餐教程系列希望能够尽可能降低门槛&#xff0c;少讲…

科普帖:什么是服务网格?

戳蓝字“CSDN云计算”关注我们哦&#xff01;译| 风车云马文| Josh Fruhlinger来源| InfoWorld网站在数字化转型的背景下&#xff0c;IT行业正在将大型的应用程序集成到小的、离散的微服务容器中&#xff0c;这些容器包含所有的服务代码和依赖项&#xff0c;而这些依赖项彼此独…

年轻人,你为什么来阿里做技术?

摘要&#xff1a; 一个阿里IT男&#xff0c;成了母婴专家? 最近&#xff0c;阿里算法工程师拉普当上了爸爸。 两个月前他就开始为这件事忙活。自从老婆有喜之后&#xff0c;七大姑八大姨都来给他提供参考&#xff0c;生过孩子的朋友、同事都对他说什么该买&#xff0c;主管也时…

查一个字段中字符集超过30的列_详细解读MySQL的30条军规

一、基础规范&#xff08;1&#xff09;必须使用InnoDB存储引擎 解读&#xff1a;支持事务、行级锁、并发性能更好、CPU及内存缓存页优化使得资源利用率更高&#xff08;2&#xff09;必须使用UTF8字符集 解读&#xff1a;万国码&#xff0c;无需转码&#xff0c;无乱码风险&am…

ThinkPHP 5使用OSS

摘要&#xff1a; ThinkPHP 5使用OSS示例。准备工作登录阿里云官网&#xff0c;将鼠标移至产品找到并单击对象存储OSS打开OSS产品详情页面。在OSS产品详情页中的单击立即开通。开通服务后&#xff0c;在OSS产品详情页面单击管理控制台直接进入OSS管理控制台界面。您也可以单击位…