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

赣州营销型网站策划sqlite 网站开发

赣州营销型网站策划,sqlite 网站开发,各大网站创始人,wordpress演示版开始之前 Composition API 可以说是Vue3的最大特点#xff0c;那么为什么要推出Composition Api#xff0c;解决了什么问题#xff1f; 通常使用Vue2开发的项目#xff0c;普遍会存在以下问题#xff1a; 代码的可读性随着组件变大而变差每一种代码复用的方式#xff… 开始之前 Composition API 可以说是Vue3的最大特点那么为什么要推出Composition Api解决了什么问题 通常使用Vue2开发的项目普遍会存在以下问题 代码的可读性随着组件变大而变差每一种代码复用的方式都存在缺点TypeScript支持有限 以上通过使用Composition Api都能迎刃而解 正文 一、Options Api Options API即大家常说的选项API即以vue为后缀的文件通过定义methodscomputedwatchdata等属性与方法共同处理页面逻辑 如下图 可以看到Options代码编写方式如果是组件状态则写在data属性上如果是方法则写在methods属性上… 用组件的选项 (data、computed、methods、watch) 组织逻辑在大多数情况下都有效 然而当组件变得复杂导致对应属性的列表也会增长这可能会导致组件难以阅读和理解 二、Composition Api 在 Vue3 Composition API 中组件根据逻辑功能来组织的一个功能所定义的所有 API 会放在一起更加的高内聚低耦合 即使项目很大功能很多我们都能快速的定位到这个功能所用到的所有 API 三、对比 下面对Composition Api 与Options Api进行两大方面的比较 逻辑组织逻辑复用 逻辑组织 Options API 假设一个组件是一个大型组件其内部有很多处理逻辑关注点对应下图不用颜色 可以看到这种碎片化使得理解和维护复杂组件变得困难 选项的分离掩盖了潜在的逻辑问题。此外在处理单个逻辑关注点时我们必须不断地“跳转”相关代码的选项块 Compostion API 而Compositon API正是解决上述问题将某个逻辑关注点相关的代码全都放在一个函数里这样当需要修改一个功能时就不再需要在文件中跳来跳去 下面举个简单例子将处理count属性相关的代码放在同一个函数了 function useCount() {let count ref(10);let double computed(() {return count.value * 2;});const handleConut () {count.value count.value * 2;};console.log(count);return {count,double,handleConut,}; }组件上中使用count export default defineComponent({setup() {const { count, double, handleConut } useCount();return {count,double,handleConut}}, });再来一张图进行对比可以很直观地感受到 Composition API 在逻辑组织方面的优势以后修改一个属性功能的时候只需要跳到控制该属性的方法中即可 逻辑复用 在Vue2中我们是用过mixin去复用相同的逻辑 下面举个例子我们会另起一个mixin.js文件 export const MoveMixin {data() {return {x: 0,y: 0,};},methods: {handleKeyup(e) {console.log(e.code);// 上下左右 x yswitch (e.code) {case ArrowUp:this.y--;break;case ArrowDown:this.y;break;case ArrowLeft:this.x--;break;case ArrowRight:this.x;break;}},},mounted() {window.addEventListener(keyup, this.handleKeyup);},unmounted() {window.removeEventListener(keyup, this.handleKeyup);}, };然后在组件中使用 templatedivMouse position: x {{ x }} / y {{ y }}/div /template script import mousePositionMixin from ./mouse export default {mixins: [mousePositionMixin] } /script使用单个mixin似乎问题不大但是当我们一个组件混入大量不同的 mixins 的时候 mixins: [mousePositionMixin, fooMixin, barMixin, otherMixin]会存在两个非常明显的问题 命名冲突数据来源不清晰 现在通过Compositon API这种方式改写上面的代码 import { onMounted, onUnmounted, reactive } from vue; export function useMove() {const position reactive({x: 0,y: 0,});const handleKeyup (e) {console.log(e.code);// 上下左右 x yswitch (e.code) {case ArrowUp:// y.value--;position.y--;break;case ArrowDown:// y.value;position.y;break;case ArrowLeft:// x.value--;position.x--;break;case ArrowRight:// x.value;position.x;break;}};onMounted(() {window.addEventListener(keyup, handleKeyup);});onUnmounted(() {window.removeEventListener(keyup, handleKeyup);});return { position }; }在组件中使用 templatedivMouse position: x {{ x }} / y {{ y }}/div /templatescript import { useMove } from ./useMove; import { toRefs } from vue; export default {setup() {const { position } useMove();const { x, y } toRefs(position);return {x,y,};}, }; /script可以看到整个数据来源清晰了即使去编写更多的 hook 函数也不会出现命名冲突的问题 小结 在逻辑组织和逻辑复用方面Composition API是优于Options API因为Composition API几乎是函数会有更好的类型推断。Composition API 对 tree-shaking 友好代码也更容易压缩Composition API中见不到this的使用减少了this指向不明的情况如果是小型组件可以继续使用Options API也是十分友好的
http://www.hkea.cn/news/14312962/

相关文章:

  • 小红书网站建设目的网站建设响应式是什么
  • 营销型网站服务重庆新闻联播历年片头
  • 佛山门户网站建设公司网站的具体步骤
  • 珠海做网站的服务公司名字
  • 营口网站建设哪家好企业网站建设东莞
  • 万网主机网站建设视频不能上传图片到网站
  • 做淘宝优惠卷网站步骤电子商务有限公司简介
  • 做网站最多的行业网上购物网站建设论文
  • 厦门网站设计培训公司2021热点新闻事件
  • 网站开发主管岗位说明中国建设银行网站会员用户名
  • 电商网站网址如何做自媒体
  • 像wordpress一样的网站温州城乡建设官网
  • 外贸网站建站m仿站小工具 wordpress
  • vs2017做网站第一个做电子商务的网站
  • 网站建设文案有趣网站内容有什么
  • 深圳做网站的公做网站价位
  • 做外贸网站案例wordpress定义页面带html
  • 设计高端网站哪家好查企业用什么软件
  • 检测网站名 注册用python做网站我那些
  • 石家庄网站定制开发怎么给网站做seo优化
  • 写作网站哪个最好上海网站制作公司怎么找
  • 上蔡县住房和城乡建设局网站棒的外贸网站建设
  • 在线做头像网站有哪些北京网站制作设计哪个公司好
  • 大连网站建设哪家好新余百度网站建设
  • 张家港做外贸网站微信免费下载2023新版
  • 广州住房与建设 网站网站宽度设计
  • 用dw做教学网站西安网站建立
  • 做网站 微信开发前景宁波网站制作怎样
  • 管理系统和网站哪个好做linux wordpress 中文字体
  • 国内做彩票网站违法么官网网站怎么做