Vue.js 一问一答

记录一下在学习 Vue 过程中给自己问的一些问题,持续更新中...

  1. Vue.js 的核心是什么?

    官网:Vue.js 的核心是一个允许采用简洁的模板语法来声明式的将数据渲染进 DOM 的系统。

    以下面的例子来说明:

    // Vue 中的模板语法
    <div id="app">
      {{message}}
    </div>
    
    var app = new Vue({
      el: "#app",
      data: {
        message: "hello Vue"
      }
    })

    上面的例子中上面的 div 是 Vue 中的模板写法,通过模板语法将数据 message 渲染进了 DOM 中。

  2. 计算属性和计算方法有什么区别?

    计算属性有缓存机制,只有和它相关的属性改变时才会重新渲染,而计算方法则是只要属性变化就会改变。

    例: 全名 FullName 用计算属性和计算方法都可以实现,当用计算属性时,只要当名或姓改时才会重新渲染,而当用计算方法时,就算是改变年龄也会重新渲染。

    在这一点上,计算方法是优于计算属性的。

  3. 如何做到数组变化的时候页面跟着变化?

    • 使用 数组方法:push, pop, shift, unshift, splice, sort, reverse.

    • 改变数组的引用,比如给这个数组重新赋予一个新的数组。

    • 利用 set 方法修改数组的值,例如:

      Vue.set(vm.list, 1, 5) // 将 list 数组索引为1的项改为5
      // 或
      vm.$set(vm.list, 1, 5)
  4. 如何做到对象变化时页面跟着变化?

    • 如果是对象中已有的属性,那么改变这个属性的值页面就会跟着变化。
    • 如果往对象里面添加属性,那么页面不会跟着变化,想让其变变化可以改变对象的引用,比如给这个对象重新赋予一个新的对象。

    • 通过 set 方法给对象设置属性,页面也会跟着变化。例如:

      Vue.set(vm.userInfo, 'sala', 'secret')
      // 或
      vm.$set(vm.userInfo, 'sala', 'secret')
  5. 想要在 tbody, select, ul, ol 等元素中使用 VUe 组件应该怎么实现?

    由于它们的特殊性,直接将组件写在这些元素中,会发现组件虽然在页面上显示,但是它们并不包裹在这些标签之中。

    解决方法: 使用 is

    // 假设 row 是一个组件,想要作为 tbody 的子元素
    <table>
      <tbody>
        <tr is='row'></tr>
        <tr is='row'></tr>
      </tbody>
    </table>
  6. 说一下当点击子组件时子组件中的 number + 1,如何实现同时父组件中的 counter 也跟着 + 1 ?

    • 在子组件中定义事件处理函数,事件处理函数的内容:

      • 当点击子组件时实现子组件的 number + 1
      • 触发一个新的事件
    • 父组件捕获这个事件,父组件事件处理函数的内容是将子组件的number赋给父组件中的 counter。

    • 在父组件中如何获得子组件的number属性呢?

      可以在使用子组件时设置 ref 属性,这样在父组件的事件处理函数中就可以获得子组件中的数据了。

  7. 父子组件如何传值?

    • 父组件如何向子组件中传值?

      • 使用子组件时设置属性的方式

        <父组件>
          // 这样写时传给子组件的是一个字符串 "1"
          <子组件 count="1"></子组件>
          // 这样写时传给子组件的是数字1,因为这样写双引号后面的内容是一个JS表达式
          <子组件 :count="1"></子组件>
        </父组件>
    • 子组件如何向父组件传值?

      • 通过事件触发的方式

      在子组件中通过 this.$emit('触发的事件名', 向父组件传入的参数) 方式,触发一个事件,在使用子组件的地方捕获到这个事件,然后触发写在父组件事件处理函数。父组件的事件处理函数可以接受到从子组件传递过来的数据。

      当然也可以通过问题 6 中 ref 方式向父组件中传值,但是无论哪种方式都需要采用事件触发的方式。

    • 何为单向数据流,为什么要规定单向数据流?

      • 单向数据流指的就是子组件不能修改从父组件传递过来的数据。
      • 如果从父组件传递过来的数据是一个引用类型的话,在子组件中如果将其改变之后,那么父组件传递给其它组件时也将是修改之后的数据。

Vue.js 一问一答的更多相关文章

  1. [译]Node.js面试问与答

    原文: http://blog.risingstack.com/node-js-interview-questions/ 什么是error-first callback? 如何避免无休止的callba ...

  2. 定了,这个vue.js开源项目,面试时,一定会考问

     因为现在的网店,都是用的商城系统, 而实体店都是入座后,扫码打开网上商城进行选购(餐饮,超市等),所以,vue.js迅速开发网上购物商城系统成为了香饽饽, 本人开源2020年4月开发的购物商城系统, ...

  3. 前端框架本质之探究——以Vue.js为例

    问:我们在使用Vue时,实际上干了什么?   答:实际上只干了一件事——new了一个Vue对象.后面的事,都交由这个对象自动去做.就好像按了下开关,机器跑起来了,剩下的事就不用我们再操心了.   各位 ...

  4. 每天记录一点:NetCore获得配置文件 appsettings.json vue-router页面传值及接收值 详解webpack + vue + node 打造单页面(入门篇) 30分钟手把手教你学webpack实战 vue.js+webpack模块管理及组件开发

    每天记录一点:NetCore获得配置文件 appsettings.json   用NetCore做项目如果用EF  ORM在网上有很多的配置连接字符串,读取以及使用方法 由于很多朋友用的其他ORM如S ...

  5. vue.js 中 data, prop, computed, method,watch 介绍

    vue.js 中 data, prop, computed, method,watch 介绍 data, prop, computed, method 的区别 类型 加载顺序 加载时间 写法 作用 备 ...

  6. 前端面试:Vue.js常见的问题

    摘自今日头条用户:代码开发 原文链接: https://www.toutiao.com/a6683120112255369732/?tt_from=mobile_qq&utm_campaign ...

  7. Vue.js——vue-resource全攻略

    概述 上一篇我们介绍了如何将$.ajax和Vue.js结合在一起使用,并实现了一个简单的跨域CURD示例.Vue.js是数据驱动的,这使得我们并不需要直接操作DOM,如果我们不需要使用jQuery的D ...

  8. Vue.js——基于$.ajax实现数据的跨域增删查改

    概述 之前我们学习了Vue.js的一些基础知识,以及如何开发一个组件,然而那些示例的数据都是local的.在实际的应用中,几乎90%的数据是来源于服务端的,前端和服务端之间的数据交互一般是通过ajax ...

  9. Vue.js 入门指南之“前传”(含sublime text 3 配置)

    题记:关注Vue.js 很久了,但就是没有动手写过一行代码,今天准备入手,却发现自己比菜鸟还菜,于是四方寻找大牛指点,才终于找到了入门的“入门”,就算是“入门指南”的“前传”吧.此文献给跟我一样“白痴 ...

随机推荐

  1. 2019-9-26:渗透测试,基础学习,js正则以及什么是目录扫描,笔记

    js正则表达式,用单个字符串描述或者匹配符合特定语句规则的字符串,相当于一种搜索模式.一些字符序列组合在一起,可以简单也可以复杂模式的,可以去搜索还可以替换 正则表达式语法/表达式/修饰符(可选),例 ...

  2. Fortran输入输出与声明--xdd

    1.建议程序总体格式: program ex1. ... end progr 2.想要打出 My name is "xdd". write(*,*)" My name i ...

  3. 网页解析--BeautifulSoup练习

    # coding = utf-8 # BeautifulSoup 主要功能是解析提取HTML数据 # re lxml bs4 # pip install Beautifulsoup4 # from b ...

  4. SpringBoot项目集成Hystrix

    Hystrix Hystrix是由Netflix开源的一个服务隔离组件,通过服务隔离来避免由于依赖延迟.异常,引起资源耗尽导致系统不可用的解决方案. 1.什么是服务熔断   服务熔断就是对该服务的调用 ...

  5. NER

    写在前面:在初学nlp时的第一个任务——NER,尝试了几种方法,cnn+crf.lstm+crf.bert+lstm+crf,毫无疑问,最后结果时Bert下效果最好. 1.关于NER: NER即命名实 ...

  6. OSI-传输层

    OSI-传输层 端口号(2字节 SYN(1bit) ACK(1bit) 会话多路复用(为什么一个IP地址可以做很多事情?) 源端口地址可以不同 五元组(世界上没有相同的2个五元组) 源IP地址-目的I ...

  7. firefox-5.x关于img标签的load事件、svg、ff5.4audio标签显示的适配tip

    1.firefox中img标签的load事件后获取图片宽高错误. 需求是根据图片加载后的大小宽高比,调整图片显示的宽高. 在chrome浏览器下,使用jquery的load方法监听img标签的&quo ...

  8. hospital:广西大学生计算机设计大赛

    html 当时做到的就是这些了 <!DOCTYPE html><html lang="en"><head> <title>病人信息查 ...

  9. 小白学 Python 爬虫(15):urllib 基础使用(五)

    人生苦短,我用 Python 前文传送门: 小白学 Python 爬虫(1):开篇 小白学 Python 爬虫(2):前置准备(一)基本类库的安装 小白学 Python 爬虫(3):前置准备(二)Li ...

  10. 《手把手教你》系列进阶篇之1-python+ selenium自动化测试 - python基础扫盲(详细教程)

    1. 简介 如果你从一开始就跟着宏哥看博客文章到这里,基础篇和练习篇的文章.如果你认真看过,并且手动去敲过每一篇的脚本代码,那边恭喜你,至少说你算真正会利用Python+Selenium编写自动化脚本 ...