Vue实例

简介: Vue实例

const vm = new Vue({})这就是一个vue的实例

参数写在大括号里,下面就讲一讲括号里的内容,本章讲解的主要知识点是


  • el和mount挂载点
  • data数据
  • methods方法
  • 组件components和component
  • 四个钩子和生命周期
  • props组件传参

微信图片_20230106161452.png


el和mount 两种挂载点的用法


挂载点:要替换容器上的哪一块,通常在html上用id标识


el的使用方法


直接写在参数里,oldCode就是id名

 const vm = new Vue({
   el:'#oldCode', 
  })

mount的使用方法

//可以使用链式方法
  const vm = new Vue({
   el:'#oldCode', 
  }).$mount('#oldCode')
  //也可以在实例名后面
  vm.$mount('#oldCode')

data 数据的两种写法


data是内部数据,建议使用函数写法


对象

  const vm = new Vue({
   el:'#oldCode', 
   data:{
        n:0
   },
  })

另一种方式是函数(推荐使用)


函数写法需要将数据写在return返回值里面

 const vm = new Vue({
     el:'#oldCode', 
     data(){
        return{
          n:0
        }
    },
  })

methods方法


add是方法名

const vm = new Vue({
     el:'#oldCode', 
     data(){
        return{
          n:0
        }
    },
    methods:{
      add(){
        this.n+=1
      }
  }
  })

组件的三种写法


方法一:新建一个文件,再将其引入(推荐使用)


1.新写一个.vue文件,文件名建议全小写


文件的内容有三大部分

用来写视图的,

除了视图外的其他选项export default { },

写样式的

<template>
<!-- 写视图 -->
    <div class="red">
        demo
    </div>
</template>
<script>
// 除了视图外的其他选项
export default {
    data(){
        return {
            n:0
        }
    },
    methods:{
        add(){
            this.n+=1
        }
    }
};
</script>
<style scoped>
.red{
    color:red;
}
</style>

2.在main.js中引入

导入文件

import 名字 from '文件路径'
import Demo from './demo.vue'
  const vm = new Vue({
  //告诉程序我要使用的组件是谁,和它对应的值
    components:{
      Demo:Demo
    },
     el:'#oldCode', 
     data(){
        return{
          n:0
        }
    },
  })

方法二:直接在main.js中创建并引用


使用component,第一个参数是组件名,第二个是模板

//新建的组件
+ Vue.component('Demo',{
+   template:`
+   <div>demo方式二</div>
+   `
+ })
const vm = new Vue({
  el:"#oldCode"
  data:{
    n:0
  },
  template:`
    <div class="red">
      {{n}}
      <button @click="add">+1</button>
      <Frank/>
      //引入组件
+      <Demo />
    </div>
  `,
  methods:{
    add(){
      this.n+=1
    },

方法三就是将上面两种方法结合起来使用

  components:{
    Demo3:{
    data(){
        return {n:0}
        }
    },
    template:`
       <div>demo3方式三   {{n}}</div>
    `
  },

四个钩子,生命周期


使用debugger调试方法, 验证这几个周期需要配合这组件一起使用

  1. created-实例出现在内存中
  2. mounted-实例出现在页面中
  3. updated-实例更新了
  4. destroyed-实例消亡了
created(){
  console.log('出现在内存中,没有出现在页面中')
},
mounted() {
  debugger
  console.log('我已经出现在页面中')
},
updated(){
  console.log('数据更新时会出现')
},
destroyed(){
  console.log('实例消失时就出现')
}

props组件传参


在组件中传参,需要先创建一个组件,这里创建一个文件

1.使用{{}}在模板里占位,在props里声明传入的参数

<template>
  <div class="red">
+    {{message}}
  </div>
</template>
<script>
export default {
+  props:['message']
}
</script>
<style scoped>
.red{
  color: red;
  border: 1px solid blue;
}
</style>

2.在实例中引入并传参,此时传入的只是一个字符串

//引入组件
  components:{Demo},
  data:{
    visible:true
    n:0
  },
  template:`
      <div>
      //传入参数,参数名要和组件里的参数名一致
  +      <Demo message="你好222" />
      </div>
  `,

3.要想将实例中的数据变量传如组件中需要在参数名前面加:,此时传入的才是变量值

<Demo :message="n" />

传入函数


1.函数需要先在实例中定义好,在组件标签里写入 参数="函数名",这里也要使用:fn就是传入的参数,add则是函数名

<Demo :message="n" :fn="add" />

2.在组件中定义和声明

 <template>
   <div class="red">
     {{message}}
     //函数的参数名
    <button @click="fn">+1</button>
   </div>
 </template>
 <script>
   export default {
   //声明参数
   props:['message','fn']
   }
 </script>
目录
相关文章
|
25天前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
127 1
|
5天前
|
JavaScript 安全 API
iframe嵌入页面实现免登录思路(以vue为例)
通过上述步骤,可以在Vue.js项目中通过 `iframe`实现不同应用间的免登录功能。利用Token传递和消息传递机制,可以确保安全、高效地在主应用和子应用间共享登录状态。这种方法在实际项目中具有广泛的应用前景,能够显著提升用户体验。
30 8
|
5天前
|
存储 设计模式 JavaScript
Vue 组件化开发:构建高质量应用的核心
本文深入探讨了 Vue.js 组件化开发的核心概念与最佳实践。
32 1
|
2月前
|
JavaScript 前端开发 开发者
vue 数据驱动视图
总之,Vue 数据驱动视图是一种先进的理念和技术,它为前端开发带来了巨大的便利和优势。通过理解和应用这一特性,开发者能够构建出更加动态、高效、用户体验良好的前端应用。在不断发展的前端领域中,数据驱动视图将继续发挥重要作用,推动着应用界面的不断创新和进化。
106 58
|
1月前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。
|
2月前
|
JavaScript API 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
JavaScript 前端开发 开发者
Vue是如何劫持响应式对象的
Vue是如何劫持响应式对象的
66 18
|
2月前
|
JavaScript 前端开发 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
存储 JavaScript 前端开发
介绍一下Vue的核心功能
介绍一下Vue的核心功能
|
2月前
|
JavaScript 前端开发 API
介绍一下Vue中的响应式原理
介绍一下Vue中的响应式原理
46 1