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

大名网站建设费用雄安免费网站建设电话

大名网站建设费用,雄安免费网站建设电话,百合怎么doi怎么做网站,重庆一站式建设网站平台💗💗💗欢迎来到我的博客,你将找到有关如何使用技术解决问题的文章,也会找到某个技术的学习路线。无论你是何种职业,我都希望我的博客对你有所帮助。最后不要忘记订阅我的博客以获取最新文章,也欢…

💗💗💗欢迎来到我的博客,你将找到有关如何使用技术解决问题的文章,也会找到某个技术的学习路线。无论你是何种职业,我都希望我的博客对你有所帮助。最后不要忘记订阅我的博客以获取最新文章,也欢迎在文章下方留下你的评论和反馈。我期待着与你分享知识、互相学习和建立一个积极的社区。谢谢你的光临,让我们一起踏上这个知识之旅!
请添加图片描述

文章目录

  • 🍋OptionsAPI 与 CompositionAPI
    • 🍋对比
  • 🍋介绍
  • 🍋setup 的返回值
  • 🍋Setup语法糖
    • 🍋完整代码如下
  • 🍋总结

🍋OptionsAPI 与 CompositionAPI

Options API

Options API 是 Vue.js 2.x 中使用的传统组件设计模式。它基于选项对象,将组件的数据、计算属性、方法、生命周期钩子等功能按照选项的形式进行组织。Options API 的特点包括:

易于上手:Options API 的结构清晰,容易理解和学习,适合初学者入门。
逻辑分离:不同功能的代码被分离到不同的选项中,使得代码更易维护和阅读。
依赖注入:通过 this 上下文可以方便地访问到组件的属性和方法。

Composition API

Composition API 是 Vue.js 3.x 中引入的新特性,旨在解决 Options API 在复杂组件中难以维护的问题。Composition API 允许将组件的逻辑按照功能相关性进行组织,而不是按照选项分散组织。Composition API 的特点包括:

逻辑复用:可以将逻辑抽取为可复用的函数,更方便地在不同组件之间共享逻辑。
代码组织:将相关逻辑放在一起,使得组件更加清晰和易于维护。
更好的类型推断:由于函数可以提供更多信息,TypeScript 在使用 Composition API 时能够提供更好的类型推断。

🍋对比

Options类型的 API,数据、方法、计算属性等,集中在:datamethodscomputed中的,若想改动一个需求,就需要分别修改:datamethodscomputed,不便于维护和复用。

Composition 可以用函数的方式,更加优雅的组织代码,让相关功能的代码更加有序的组织在一起。

上面我将两种形式的API都列出来了,总的来说OptionsAPI属于Vue2,CompositionAPI属于Vue3,本文主要结合两者进行介绍

🍋介绍

在 Vue3 中,setup 函数是一个新引入的概念,它代替了之前版本中的 data、computed、methods 等选项,用于设置组件的初始状态和逻辑。setup 函数的引入使得组件的逻辑更加清晰和灵活,本文将主要介绍Setup的基本用法和少量原理

  • 更灵活的组织逻辑:setup 函数可以将相关逻辑按照功能进行组织,使得组件更加清晰和易于维护。不再受到 Options API 中选项的限制,可以更自由地组织代码。

  • 逻辑复用:可以将逻辑抽取为可复用的函数,并在 setup 函数中进行调用,实现逻辑的复用,避免了在 Options API 中通过 mixins 或混入对象实现逻辑复用时可能出现的问题。

  • 更好的类型推断:由于 setup 函数本身是一个普通的 JavaScript 函数,可以更好地与 TypeScript 配合,提供更好的类型推断和代码提示。

  • 更好的响应式处理:setup 函数中可以使用 ref、reactive 等函数创建响应式数据,可以更方便地处理组件的状态,实现数据的动态更新。

  • 更细粒度的生命周期钩子:setup 函数中可以使用 onMounted、onUpdated、onUnmounted 等函数注册组件的生命周期钩子,可以更细粒度地控制组件的生命周期行为。

  • 更好的代码组织:setup 函数将组件的逻辑集中在一个地方,使得代码更易读、易维护,并且可以更清晰地看到组件的整体逻辑。

上述特点有些暂时用不到,本节主要介绍下面三个特点

  • setup函数返回的对象中的内容,可直接在模板中使用。
  • setup中访问thisundefined
  • setup函数会在beforeCreate之前调用,它是“领先”所有钩子执行的。
    在这里插入图片描述
    从下面的图就可以看出Setup的执行要更优先,以及this的不适用
    在这里插入图片描述
<template><div class="person"><h2>姓名:{{name}}</h2><h2>年龄:{{age}}</h2><button @click="changeName">修改名字</button><button @click="changeAge">修改年龄</button><button @click="showTel">查看联系方式</button></div></template><script lang="ts">export default {name:'Person',setup(){console.log('~',this) let name = '花卷' //非响应式let age = 22  //非响应式let tel = '12435143545'  //非响应式// 方法function changeName() {name = '馒头' console.log(name) }function changeAge() {age += 1 console.log(age) }function showTel() {alert(tel)}// 将数据、方法交出去return {name,age,tel,changeName,changeAge,showTel}}}</script>

🍋setup 的返回值

  • 若返回一个对象:则对象中的:属性、方法等,在模板中均可以直接使用**(重点关注)。**

在这里插入图片描述

  • 若返回一个函数:则可以自定义渲染内容,代码如下:
setup(){return ()=> '你好啊!'
}

🍋Setup语法糖

大家十分清楚语法糖到哪都是为了使代码更简便

接下来我介绍一下语法糖的写法

<script setup>
</script>

它可以自动返回,无需return返回,我们测试一下,首先在模版把a写上

在这里插入图片描述
然后再script里面写,这里的let a = 111,就自带返回了,我们接下来看看页面

<script setup>let a = 111
</script>

很不幸,报错了,我们读一下报错内容,两个标签必须采用相同类型,那么我们统一就好
在这里插入图片描述
在这里插入图片描述

<script lang="ts" setup>let a = 111
</script>

这样结果就出来了
在这里插入图片描述

我们如果想要修改下面的名字,除了重命名文件(大部分情况不采用),可以采用一个插件
在这里插入图片描述
我们可以借助vite中的插件简化

  1. 第一步控制台运行:npm i vite-plugin-vue-setup-extend -D
  2. 第二步:vite.config.ts
    在这里插入图片描述

🍋完整代码如下

<template><div class="person"><h2>姓名:{{name}}</h2><h2>年龄:{{age}}</h2><h2>地址:{{address}}</h2><button @click="changeName">修改名字</button><button @click="changeAge">修改年龄</button><button @click="showTel">查看联系方式</button></div>
</template><script lang="ts" setup name="Person">  //自定义命名// 此时的name、age、tel都不是响应式的数据let name = '张三'let age = 22let tel = '1424423451'let address = '北京市朝阳区'// 方法function changeName() {name = '' console.log(name) }function changeAge() {age += 1 console.log(age)}function showTel() {alert(tel)}
</script>

🍋总结

一开始介绍了Vue2,3对应的两种API以及对比,之后简单介绍了一下Vue3特有的函数—Setup,最后围绕Setup介绍使用语法糖后,可以省略 export default 和 setup 属性,使得组件的代码更加简洁和易读。同时,Vue 3 也会将 参数地注入到 setup 函数中,使得在使用这些参数时不需要显式地声明。

请添加图片描述

挑战与创造都是很痛苦的,但是很充实。

http://www.yayakq.cn/news/874692/

相关文章:

  • 关于大棚建设的网站商品网站建设实验报告
  • 比较好的网页模板网站wordpress 数据库 改ip
  • 中国网站空间wordpress 公网贷款
  • 3000ok新开传奇网站石家庄网站快速优化排名
  • 地方文明网站建设措施流量打不开网站怎么办
  • 刘金鹏做网站wordpress 豆瓣主题
  • 女人与狗做网站办公家具
  • 做酸菜视频网站岳阳公司网站开发
  • 网站动态页面怎么做wordpress打赏key插件
  • 购物网站建设 优帮云公司注册域名怎么申请
  • 学生自做网站优秀作品新手学做网站电子版
  • 网站开发小组沈阳蓝德网站建设
  • 网站内链怎么删除种子资源地址
  • o2o网站建设策划新闻热点事件2021(最新)
  • 东莞百度代做网站联系方式企业官方网站怎么写
  • 代理怎么引流推广seo网络推广经理招聘
  • 服务好的网站开发郑州微信网站制作
  • 昆明专业做网站网站备案个人信息
  • 做网站要用到哪些架包鄂州网站建设设计
  • 做网站卖产品投资大嘛滁州58同城网站怎么做
  • 有没有专业做盐的网站在中国怎么做国外网站
  • 网站建设列表网wordpress询盘插件
  • 网站 用户登陆 模板品牌网站建设十a小蝌蚪
  • 小企业网站建设的服务机构网站内容建设机制
  • 美容美发网站源码五百丁简历官网
  • 电子书网站用dz还是wordpresswordpress更换图标
  • 优秀网站开发网站开发与设计实训总结两千字
  • 贵州企业品牌网站建设非遗网页设计作品欣赏
  • 北京网站制作推广wordpress带视频
  • 湖南网站建设网会外语和做网站