当前位置: 首页 > article >正文

UniApp在Vue3下使用setup语法糖创建和使用自定义组件

UniApp在Vue3下使用setup语法糖创建和使用自定义组件

在现代前端开发中,Vue 3 的 <script setup> 语法糖极大地简化了组件的编写和使用。本文将详细介绍如何在 UniApp 中使用 Vue 3 的 <script setup> 语法创建自定义组件,并在其他组件中使用这些自定义组件。

1. 创建自定义组件

首先,我们创建一个简单的自定义组件 MyComponent.vue。这个组件将接收一些属性,并展示一些基本内容。

MyComponent.vue

<template>
  <view :style="styleObject">
    <p v-if="showText">{{ text }}</p>
    <p>Number: {{ number }}</p>
    <p>Boolean: {{ boolean }}</p>
    <ul>
      <li v-for="item in array" :key="item">{{ item }}</li>
    </ul>
    <p>Object: {{ object.name }} - {{ object.age }}</p>
    <button @click="emitEvent">点击触发事件</button>
  </view>
</template>

<script setup>
import { defineProps, defineEmits, computed } from 'vue';

// 定义接收的 props
const props = defineProps({
  text: {
    type: String,
    default: '默认文本'
  },
  number: {
    type: Number,
    default: 0
  },
  boolean: {
    type: Boolean,
    default: false
  },
  array: {
    type: Array,
    default: () => []
  },
  object: {
    type: Object,
    default: () => ({ name: '默认名字', age: 20 })
  }
});

// 定义触发的事件
const emit = defineEmits(['customEvent']);

// 计算属性,用于处理样式对象
const styleObject = computed(() => ({
  marginTop: props.number + 'px',
  color: props.boolean ? 'red' : 'black'
}));

// 方法:触发自定义事件
const emitEvent = () => {
  emit('customEvent', '这是一个自定义事件');
};
</script>

<style scoped>
/* 组件内的局部样式 */
button {
  margin-top: 10px;
}
</style>

详细解释

1.1 定义属性 (defineProps)

MyComponent.vue 中,我们使用 defineProps 来定义组件可以接收的属性。每个属性都有一个类型和默认值:

const props = defineProps({
  text: {
    type: String,
    default: '默认文本'
  },
  number: {
    type: Number,
    default: 0
  },
  boolean: {
    type: Boolean,
    default: false
  },
  array: {
    type: Array,
    default: () => []
  },
  object: {
    type: Object,
    default: () => ({ name: '默认名字', age: 20 })
  }
});
1.2 定义事件 (defineEmits)

我们使用 defineEmits 来定义组件可以触发的事件。在这个例子中,我们定义了一个名为 customEvent 的事件:

const emit = defineEmits(['customEvent']);
1.3 计算属性 (computed)

我们使用 computed 来创建一个计算属性 styleObject,它根据传递的 numberboolean 属性生成样式对象:

const styleObject = computed(() => ({
  marginTop: props.number + 'px',
  color: props.boolean ? 'red' : 'black'
}));
1.4 方法 (emitEvent)

我们定义了一个方法 emitEvent,当用户点击按钮时,触发 customEvent 事件,并传递一个消息:

const emitEvent = () => {
  emit('customEvent', '这是一个自定义事件');
};

2. 使用自定义组件

接下来,我们在另一个 .vue 文件中导入并使用这个自定义组件,同时传递属性和监听事件。

App.vue

<template>
  <view>
    <MyComponent 
      text="你好,世界!"
      :number="50"
      :boolean="true"
      :array="['苹果', '香蕉', '橙子']"
      :object="{ name: '张三', age: 30 }"
      @customEvent="handleCustomEvent"
    />
  </view>
</template>

<script setup>
import MyComponent from './components/MyComponent.vue';

// 定义一个方法来处理自定义事件
const handleCustomEvent = (message) => {
  console.log('自定义事件触发:', message);
};
</script>

<style>
/* 页面级别的样式 */
</style>

详细解释

2.1 导入和使用自定义组件

App.vue 中,我们导入 MyComponent 并在模板中使用它,同时传递属性和监听事件:

<MyComponent 
  text="你好,世界!"
  :number="50"
  :boolean="true"
  :array="['苹果', '香蕉', '橙子']"
  :object="{ name: '张三', age: 30 }"
  @customEvent="handleCustomEvent"
/>
2.2 处理自定义事件

我们定义了一个方法 handleCustomEvent 来处理自定义事件 customEvent

const handleCustomEvent = (message) => {
  console.log('自定义事件触发:', message);
};

总结

通过以上步骤,我们创建了一个自定义组件 MyComponent,并在 App.vue 中使用它。我们传递了多种类型的属性,并且监听了自定义事件。这种方式使得组件的复用性和可维护性大大增强。


http://www.kler.cn/a/404060.html

相关文章:

  • Python创建虚拟环境报错:Error: Command......
  • 菜鸟驿站二维码/一维码 取件识别功能
  • wsl虚拟机中的dockers容器访问不了物理主机
  • 【机器学习】回归模型(线性回归+逻辑回归)原理详解
  • 葡萄酒(wine)数据集——LDA、贝叶斯判别分析
  • Elasticsearch:管理和排除 Elasticsearch 内存故障
  • C++桥接模式在使用时需要注意什么
  • 算法定制LiteAIServer检测算法入侵检测算法平台部署:危险区域人员闯入治理
  • Python中Tushare(金融数据库)入门详解
  • 【pytorch-02】:张量的索引、形状操作和常见运算函数
  • 2024强网杯--babyheap house of apple2解法
  • Unity3d场景童话梦幻卡通Q版城镇建筑植物山石3D模型游戏美术素材
  • 细说STM32单片机DMA中断收发RTC实时时间并改善其鲁棒性的另一种方法
  • SAP Ariba Contracts 基本介绍
  • 知识见闻 - 数学: 均方根误差和标准差
  • 密码学之柯克霍夫原则(Kerckhoff原则)
  • 美创科技入选2024数字政府解决方案提供商TOP100!
  • jmeter常用配置元件介绍总结之监听器
  • C++编程玩转物联网:用树莓派Pico实现流水灯
  • react中useMemo的使用场景
  • vue学习11.21
  • 多模态大模型(4)--InstructBLIP
  • python中Pandas操作excel补全内容
  • 无人机与低空经济:开启新质生产力的新时代
  • Makefile 之 自动化变量
  • brpc 与 Etcd 二次封装