vue3速览

简介: vue3速览

在您的Vue.js 3应用中,createApp 是用于创建一个Vue应用实例的函数。您已经正确地引入了它并开始创建应用,但目前根组件内部是空的。下面我将为您展示一个更完整的例子,说明如何设置根组件的模板、数据、方法等选项,并挂载到DOM上。

import { createApp } from 'vue'

const app = createApp({
  // 根组件的模板可以使用template属性定义
  template: `
    <div>
      <h1>{{ message }}</h1>
      <button @click="reverseMessage">{{ buttonText }}</button>
    </div>
  `,
  
  // 数据属性定义在setup函数中,返回一个对象
  setup() {
    let message = 'Hello Vue 3!';
    let buttonText = 'Reverse Message';

    // 方法也定义在setup函数内
    const reverseMessage = () => {
      message = message.split('').reverse().join('');
      buttonText = message === 'Hello Vue 3!' ? 'Reverse Message' : 'Original';
    };

    // 返回一个包含要注入到模板中的属性和方法的对象
    return {
      message,
      buttonText,
      reverseMessage
    };
  }
})

// 挂载应用到DOM的一个元素上,例如ID为'app'的元素
app.mount('#app')

在这个示例中,我们定义了一个简单的Vue 3应用,其根组件有一个欢迎信息和一个按钮。点击按钮会触发reverseMessage方法,该方法反转消息文本,并改变按钮的文本以反映是否显示原始消息或已反转的消息。最后,我们使用app.mount('#app')将这个应用挂载到HTML中ID为app的元素上。


记得在您的HTML文件中包含一个挂载点:

<div id="app"></div>
• 1

并且确保在使用此代码之前已经通过CDN或构建工具引入了Vue 3。

当然可以,Vue 3 应用允许你向根组件传递props。这在创建可复用的组件或需要根据外部条件初始化组件状态时非常有用。不过,与Vue 2不同,在Vue 3中,你需要在创建应用实例之后,使用app.provide()来提供全局属性,或者在挂载时直接传递props给根组件。这里展示如何直接向根组件传递props:


首先,修改你的JavaScript代码以接收props:

import { createApp } from 'vue'

const app = createApp({
  // ...
  setup(props) {
    // 现在你可以在这个函数内通过props访问传入的参数
    console.log(props.initialMessage);
    
    // 假设我们使用props来初始化message
    let message = props.initialMessage;
    // ... 其他逻辑保持不变 ...
  },
  // ...
})

然后,在挂载应用到DOM时传递props:

app.mount('#app', { initialMessage: 'Hello from props!' });

在这个例子中,我们向根组件传递了一个名为initialMessage的prop,并在setup函数中通过props参数访问它。这样,你就可以根据传递的参数来初始化应用的状态或其他配置了。


请注意,这种方式适用于简单场景或快速原型开发。对于更复杂的应用,推荐使用Vue的依赖注入系统(provide/inject)或者利用路由参数、状态管理库(如Vuex)来传递和管理状态。


目录
相关文章
|
1天前
|
缓存 JavaScript 前端开发
Vue 3的响应式系统
【5月更文挑战第31天】Vue 3的响应式系统
6 1
|
1天前
|
JavaScript 前端开发 API
vue2 /vue3【nextTick】的使用方法及实现原理,一文全搞懂!
vue2 /vue3【nextTick】的使用方法及实现原理,一文全搞懂!
|
1天前
|
JavaScript 开发者
[vue2/vue3] -- 深入剖析v-model的原理、父子组件双向绑定的多种写法
[vue2/vue3] -- 深入剖析v-model的原理、父子组件双向绑定的多种写法
[vue2/vue3] -- 深入剖析v-model的原理、父子组件双向绑定的多种写法
|
1天前
|
JavaScript API
vue3父子组件相互调用方法详解
vue3父子组件相互调用方法详解
|
8天前
|
JavaScript API
Vue3 基础语法
该内容介绍了Vue项目的创建和Vue3的语法、响应式API、生命周期、组件通信及跨组件通信方法。包括使用`npm init vue@latest`创建项目,`npm install`初始化,Vue3的`setup`语法,`reactive`、`ref`、`computed`和`watch`的用法,生命周期图解,以及父子组件间的数据传递。此外,还提到了Vue3中使用`provide`和`inject`进行跨层数据传递,以及通过Pinia库进行状态管理。
35 0
Vue3 基础语法
|
12天前
|
JavaScript 定位技术 API
在 vue3 中使用高德地图
在 vue3 中使用高德地图
22 0
|
12天前
vue3 键盘事件 回车发送消息,ctrl+回车 内容换行
const textarea = textInput.value.textarea; //获取输入框元素
28 3
|
14天前
|
设计模式 JavaScript 前端开发
Vue3报错Property “xxx“ was accessed during render but is not defined on instance
Vue3报错Property “xxx“ was accessed during render but is not defined on instance
|
15天前
|
JavaScript 前端开发 安全
Vue3官方文档速通(下)
Vue3官方文档速通(下)
28 0
|
15天前
|
JavaScript API
Vue3 官方文档速通(中)
Vue3 官方文档速通(中)
32 0