掌握Vue生命周期,让你的前端开发效率翻倍!

简介: 掌握Vue生命周期,让你的前端开发效率翻倍!

1 Vue实例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Vue实例</title>
    <script src='../vue.js'></script>
</head>
<body>
<div id="root">
    <!-- v-on可简写为@ -->
    <div @click="handleClick">
        {{message}}
    </div>
    <item></item>
</div>
<script>
    Vue.component('item', {
        template: '<div>hello item</div>'
    })
    /**
     * 每个 Vue 应用都是通过用 Vue 函数创建一个新的 Vue 实例开始
     */
    var vm = new Vue({
        /**
         * el: '#root'表示Vue实例将挂载到id为"root"的HTML元素
         * 这个HTML元素可以是任何元素 如div、section
         * Vue实例挂载到该元素后,Vue实例就可以操作该元素及其子元素,以及响应用户的交互行为
         */
        el: '#root',
        /**
         * 当一个 Vue 实例被创建时,它将 data 对象中的所有的 property 加入到 Vue 的响应式系统中
         * 当这些 property 的值发生改变时,视图将会产生“响应”,即匹配更新为新的值。
         * 只有当实例被创建时就已经存在于 data 中的 property 才是响应式的
         */
        data: {
            message: 'hello world'
        },
        // 在 `methods` 对象中定义方法
        methods: {
            handleClick: function () {
                alert("hello")
            }
        }
    })
</script>
</body>
</html>

一个 Vue 应用由一个通过 new Vue 创建的根 Vue 实例,以及可选的嵌套的、可复用的组件树组成。


所有的 Vue 组件都是 Vue 实例,并且接受相同的选项对象 (一些根实例特有的选项除外)。


组件是可复用的 Vue 实例,且带有一个名字:在这个例子中是 <item>。

<div id="root">
    <!-- v-on可简写为@ -->
    <div @click="handleClick">
        {{message}}
    </div>
    <!-- 使用item组件 -->
    <item></item>
</div>

2 Vue实例生命周期

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Vue实例生命周期函数</title>
  <script src='../vue.js'></script>
</head>
<body>
  <div id="app">Hello World</div>
  <script>
    // 生命周期函数:Vue实例在某时间点自动执行的函数
    var vm = new Vue({
      el: "#app",
      template: "<div>{{test}}</div>",
      data: {
        test: "hello world"
      },
      beforeCreate: function() {
        console.log("beforeCreate");
      },
      created: function() {
        console.log("created");
      },
      beforeMount: function() {
        console.log(this.$el);
        console.log("beforeMount");
      },
      mounted: function() {
        console.log(this.$el);
        console.log("mounted");
      },
      beforeDestroy: function() {
        console.log("beforeDestroy");
      },
      destroyed: function() {
        console.log("destroyed");
      },
      beforeUpdate: function() {
        console.log("beforeUpdate");
      },
      updated: function() {
        console.log("updated");
      }
    })
  </script>
</body>
</html>

这些方法都是单独定义,不放在 methods 对象里。

见鬼了,其它几个生命周期点呢?为啥没打印出来呢?

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Vue实例生命周期函数</title>
  <script src='../vue.js'></script>
</head>
<body>
  <div id="app">Hello World</div>
  <script>
    // 生命周期函数:Vue实例在某时间点自动执行的函数
    var vm = new Vue({
      el: "#app",
      template: "<div>{{test}}</div>",
      data: {
        test: "hello world"
      },
      // 第一个被调用
      beforeCreate: function() {
        console.log("beforeCreate");
      },
      created: function() {
        console.log("created");
      },

template

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Vue实例生命周期函数</title>
  <script src='../vue.js'></script>
</head>
<body>
  <script>
    // 生命周期函数:Vue实例在某时间点自动执行的函数
    var vm = new Vue({
      el: "#app",
      template: "<div>{{test}}</div>",
      data: {
        test: "hello world"
      },
      beforeCreate: function() {
        console.log("beforeCreate");
      },

上面这么写和下面一样:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Vue实例生命周期函数</title>
  <script src='../vue.js'></script>
</head>
<body>
  <script>
    // 生命周期函数:Vue实例在某时间点自动执行的函数
    var vm = new Vue({
      el: "#app",
      data: {
        test: "hello world"
      },
      beforeCreate: function() {
        console.log("beforeCreate");
      },

vm.$destroy()

完全销毁一个实例。清理它与其它实例的连接,解绑它的全部指令及事件监听器。


触发 beforeDestroy 和 destroyed 的钩子。


在大多数场景中你不应该调用这个方法。最好使用 v-if 和 v-for ,以数据驱动的方式控制子组件的生命周期。

update

目录
相关文章
|
26天前
|
监控 JavaScript 前端开发
vue学习第十二章(生命周期)
欢迎来到我的博客,我是瑞雨溪,一名热爱JavaScript和Vue的大一学生。本文深入探讨了Vue实例的生命周期,从初始化到销毁各阶段的关键钩子函数及其应用场景,帮助你更好地理解Vue的工作原理。如果你觉得有帮助,欢迎关注我,将持续分享更多优质内容!🎉🎉🎉
22 1
vue学习第十二章(生命周期)
|
1月前
|
Web App开发 前端开发 JavaScript
前端开发必备神器大公开,用过的人都哭了:效率翻倍不是梦!
前端开发结合了创意与技术,本文介绍了几个提升开发效率的工具:Visual Studio Code、Webpack、Postman、GitHub 和 Chrome DevTools。这些工具分别在代码编辑、模块打包、API 测试、版本控制和网页调试等方面发挥重要作用,帮助开发者提高工作效率,优化项目管理。
31 4
|
1月前
|
前端开发 JavaScript 开发者
React与Vue:前端框架的巅峰对决与选择策略
【10月更文挑战第23天】React与Vue:前端框架的巅峰对决与选择策略
|
1月前
|
前端开发 JavaScript 数据管理
React与Vue:两大前端框架的较量与选择策略
【10月更文挑战第23天】React与Vue:两大前端框架的较量与选择策略
|
1月前
|
前端开发 JavaScript 开发者
揭秘前端高手的秘密武器:深度解析递归组件与动态组件的奥妙,让你代码效率翻倍!
【10月更文挑战第23天】在Web开发中,组件化已成为主流。本文深入探讨了递归组件与动态组件的概念、应用及实现方式。递归组件通过在组件内部调用自身,适用于处理层级结构数据,如菜单和树形控件。动态组件则根据数据变化动态切换组件显示,适用于不同业务逻辑下的组件展示。通过示例,展示了这两种组件的实现方法及其在实际开发中的应用价值。
36 1
|
25天前
|
JavaScript 前端开发 搜索推荐
Vue的数据驱动视图与其他前端框架的数据驱动方式有何不同?
总的来说,Vue 的数据驱动视图在诸多方面展现出独特的优势,其与其他前端框架的数据驱动方式的不同之处主要体现在绑定方式、性能表现、触发机制、组件化结合、灵活性、语法表达以及与后端数据交互等方面。这些差异使得 Vue 在前端开发领域具有独特的地位和价值。
|
2月前
|
JavaScript 前端开发 算法
前端优化之超大数组更新:深入分析Vue/React/Svelte的更新渲染策略
本文对比了 Vue、React 和 Svelte 在数组渲染方面的实现方式和优缺点,探讨了它们与直接操作 DOM 的差异及 Web Components 的实现方式。Vue 通过响应式系统自动管理数据变化,React 利用虚拟 DOM 和 `diffing` 算法优化更新,Svelte 通过编译时优化提升性能。文章还介绍了数组更新的优化策略,如使用 `key`、分片渲染、虚拟滚动等,帮助开发者在处理大型数组时提升性能。总结指出,选择合适的框架应根据项目复杂度和性能需求来决定。
|
2月前
|
JavaScript
Vue 的父组件和子组件生命周期钩子执行顺序
在 Vue 中,父组件和子组件的生命周期钩子执行顺序如下:
|
2月前
|
前端开发 JavaScript 安全
在vue前端开发中基于refreshToken和axios拦截器实现token的无感刷新
在vue前端开发中基于refreshToken和axios拦截器实现token的无感刷新
141 4
|
2月前
|
JavaScript