Vue学习 (一)跟着官方文档入门

本文介绍了如何在Vue中直接和间接控制DOM元素,以及数据渲染的基本指令,重点讲解了数据绑定、v-model、v-bind和组件之间的prop数据传递。通过实例演示了如何通过prop将不同数据传递给组件并结合使用。

DOM元素的控制

  • 直接控制
    在vue之前,原生js通过document对象控制html元素,像jQuery简化了这个操作,但是不管怎样都是一回事:使用某个选择器通过id、class来从DOM树中选择想要操作的元素,再进行页面上的更改。

  • 间接控制
    而vue的做法是,将页面元素和变量绑定在一起,页面就会随着变量的变化而变化.这个绑定的动作在vue里的用词是挂载。(这里的变量实际上应该是vue对象,但是说变量更加直观一点)

例子

官方第一个例子给了一个基本的挂载模板,将id为“app”的html元素绑定到了app这个vue对象上。el类似于选择器的作用,data就是可以用来操作的数据了。
在这里插入图片描述
那么现在目标框内的内容显示的是Hello Vue!,现在直接通过浏览器控制台改变要怎么做呢?

  • 按传统方法,应该通过document对象获取id为’app’的元素,然后innerText来更新:
    在这里插入图片描述
    页面就会发生变化
    在这里插入图片描述
  • 而按照vue的方法,此时js里面已经有一个变量app
    在这里插入图片描述
    可以看到这个app是一个Vue对象,它挂载在id为’app’的元素上,在id为’app’的<div>标签里的内容跟随了了app对象里的成员变量message。所以直接修改变量app的message元素就可以更改’app’div里面的文本内容:
    在这里插入图片描述
    有意思的是,修改失败了。说明操作document之后破坏了vue的挂载关系,那么刷新一下页面,再试试看。
    在这里插入图片描述
    这样就是成功的。

渲染方式

先厘清一下概念
  • 绑定
    首先,vue对象和DOM元素建立联系的过程叫做的绑定。
    vue实例(对象)中el属性:代表Vue的作用范围 ,在Vue的作用范围内就可以使用Vue的语法。el属性中可以书写任意的CSS选择器[jquery选择器],但是在使用Vue开发是推荐使用 id选择器 (注意: el属性值不能指定body或html标签
    在这里插入图片描述
    vue对象的data部分和绑定无关,因为这要用另一术语来描述:数据渲染。
  • 渲染
    渲染就是页面上的数据展示,在这里就是用app对象的数据(data)控制页面元素’app’的展示内容,这里用的是双层花括号的方法,将app对象的数据成员message放到了’app’元素的文本展示区。

对于上面的例子来说,是vue对象单向挂载到了’app’元素上,因为通过document改变’app’的内容不会影响到app的message值。

数据渲染的指令

如 v-bind attribute 这样的语句被称为指令。
指令带有前缀 v-,以表示它们是 Vue 提供的特殊 attribute。

vue实例(对象)中data属性: 用来给Vue实例绑定一些相关数据, 绑定的数据可以取出操作,这个过程有下面几种指令:

  1. v-text
    通过{{变量名}}在Vue作用范围内取出数据,可以在{{}}中书写表达式,运算符,调用相关方法,以及逻辑运算等。这种双重花括号的绑定方式,是v-text的简化版本。

    v-text的一般使用是这样:

     <div v-text="msg"></div >
    

    v-text的作用类似于原生js中的innerText,是单向绑定,即数据对象上的值改变,插值会发生变化;但是当插值发生变化并不会影响数据对象的值

  2. v-html
    v-html用于输出html,它与v-text区别在于v-text输出的是纯文本,浏览器不会对其再进行html解析,但v-html会将其当html标签解析后输出。

    <div id="app">
        <p v-html="html"></p>
    </div>
    
    let app = new Vue({
            el: "#app",
            data: {
                html: "<b style='color:red'>v-html</b>"
            }
        });
    
  3. v-model

    v-model通常用于表单组件的绑定,例如input,select等。它与v-text的区别在于它实现的表单组件的双向绑定,如果用于表单控件以外标签是没有用的。

    <div id="app">
      <input v-model="message " />
    </div>
    var app = new Vue({
       el : '#app',
       data : {
        message : 'hello world'    
     }
    })
    
  4. v-bind
    官网对该指令的解释是“将这个元素节点的 title attribute 和 Vue 实例的 message property 保持一致”
    意思其实就是,用v-bind可以将data中的数据和元素中的属性绑定在一起。
    在这里插入图片描述
    这里就是将message绑定到了span标签的’title’元素。


弄清楚挂载和数据渲染的概念之后,v-for、v-if等都只是数据渲染的不同姿势而已,需要的时候参照一下官网的例子即可。下一个值得关注的知识点是组件。

组件

概念

在 Vue 里,一个组件本质上是一个拥有预定义选项的一个 Vue 实例。

官方一句话这样定义组件,说白了就是自定义的一个html标签.

例子

在这里插入图片描述
template配置的内容就是自定义标签里的内容。

数据传递

prop

对于上面的组件构建,文档里说:

但是这样会为每个待办项渲染同样的文本,这看起来并不炫酷。我们应该能从父作用域将数据传到子组件才对。

这句话的意思是说,单单按上面的方法构建组件还不够,因为这样创建一个组件在每个用到这个组件的地方都是同样的数据,得搞一个操作,让每个组件使用的时候可以传入不同的数据。

所以给出了组件定义的改良:
在这里插入图片描述
其实就是多了一个prop的配置,关于prop,官方解释为:

Prop 是你可以在组件上注册的一些自定义 attribute。当一个值传递给一个 prop attribute 的时候,它就变成了那个组件实例的一个 property。为了给博文组件传递一个标题,我们可以用一个 props 选项将其包含在该组件可接受的 prop 列表中:

Vue.component('blog-post', {
  props: ['title'],
  template: '<h3>{{ title }}</h3>'
})

通俗来讲,就是可以给自定义的html标签配上参数,就像"<div id=‘xxx’ class=‘xxx’ />"里的id、class这种参数一样。组件上配置了props里有哪些参数,使用对应标签时就可以带上这些参数。
对于上面这个组件来说,template里面使用了title这个参数传入的数据,用h3的标题格式来展示。
使用:
在这里插入图片描述

prop与data结合:

在这里插入图片描述
就是通过v-for、v-bind的操作将data里的数据赋给组件定义的参数(‘todo’)
在这里插入图片描述


好了,弄明白个大略,剩下的细节慢慢细究

### 回答1: Vue3.0是款前端框架,相比于2.x版本,3.0版本提供了更好的性能和更好的类型支持。那么,如何从零入门Vue3.0呢? 首先,需要了解些基础概念,例如Vue实例、组件、指令和计算属性等。可以通过阅读Vue官方文档或者相关书籍进行学习。另外,熟练掌握HTML、CSS以及JavaScript等基础知识也很重要。 接着,可以通过搭建个简单的开发环境来完成Vue3.0的入门。可以搜索相关的教程或者跟着官方文档进行安装步骤,然后创建Vue实例,引入些组件和指令,最后将它们渲染到页面上。 当了解了Vue3.0的基本用法后,可以通过阅读文档和实际操作来进步提高自己的技能水平。些高级的特性,例如Composition API、Teleport和Suspense等,可以帮助我们更加高效地开发应用程序。 最后,通过练习和写些小项目来巩固学习成果,例如创建个简单的To-Do-List应用或者个博客系统等,这样可以更好地掌握Vue3.0的相关知识和技巧。 综上所述,Vue3.0的零基础入门需要掌握些基础知识、搭建开发环境、了解基本用法、学习高级特性和练习实践等步骤,通过不断地探索和实践,可以更加深入地了解并掌握Vue3.0的技术。 ### 回答2: Vue 3.0 是个开源的 JavaScript 框架,用于构建现代化的 Web 应用和单页面应用。如果您是个零基础的入门者,现在学习 Vue 3.0 并不会太难,以下是入门技巧: 第步,需要了解 Vue 3.0 的基础概念和语法。Vue 入门者需要了解 Vue CLI、Vue 组件、Vue 模板、指令、插件等基础概念。同时,需要使用 web 开发技术,如 HTML、CSS 等,并能够熟练使用 JavaScript。 第二步,您可以通过阅读官方文档或参加在线教学平台来进行学习。对于初学者,Vue 3.0 官方文档提供了基础特性、组件、Api、路由、状态管理、插件等信息。此外,优质的教学网站也是个好的选择。 第三步,您可以开始进行实践项目。这些项目可以是基于 Vue 3.0 的 ToDo 应用程序、新闻客户端、简单的博客等。这些应用可以将概念与实践相结合,以加深您对 Vue 3.0 的理解。 第四步,加入开发社区并与开发者互动交流。开源社区比较活跃,您可以参与到其中,通过问答、发表评论、提出问题等方式得到帮助和学习经验。 最后,Vue 3.0 由于其易于学习和使用而受到了开发者的喜爱。只要您学习基础知识和实践经验,并成为 Vue 3.0 开发社区中的员,那么在未来的开发实践中,您将会收获很多成果。 ### 回答3: Vue.js款简单易用、高效灵活的JavaScript框架。它被广泛应用于前端开发,不仅可以用于构建单页应用和复杂的Web应用程序,还可以用于构建管理面板、后台系统等。 Vue.js 3.0是Vue.js框架的最新版本,它带来了些令人兴奋的新特性,包括更少的内存消耗、更快的运行速度和更好的类型推断。下面是些零基础入门Vue.js 3.0的步骤: 1.准备环境 在开始使用Vue.js 3.0之前,您需要在计算机上安装Node.js和npm。然后,您可以使用npm安装Vue.js 3.0的CLI。 2.创建Vue.js应用程序 使用Vue.js CLI创建个新的Vue.js应用程序。使用以下命令: vue create my-project 这条命令将创建个新的Vue.js项目。 3.学习Vue.js基础知识 Vue.js种基于组件的框架,它允许您将复杂的应用程序拆分成多个小部件。了解Vue.js的基础知识非常重要,包括模板、组件、数据绑定和事件处理程序等。 4.编写组件 编写组件是Vue.js应用程序开发的核心。您可以使用Vue.js的组件系统来创建可重用的组件,并将它们组合成个完成的应用程序。 5.使用Vue.js的路由器 Vue.js的路由器系统可以帮助您管理应用程序中的不同视图和组件之间的导航。学习使用Vue.js的路由器非常重要。 总之,Vue.js款易于学习和使用的前端开发框架。通过学习Vue.js的基础知识、编写组件、使用路由器和其他相关技术,您可以轻松地创建可重用的Vue.js应用程序。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值