0

0

Vue js 通用编码标准

WBOY

WBOY

发布时间:2024-08-08 20:16:49

|

425人浏览过

|

来源于dev.to

转载

vue js 通用编码标准

以下是 vue.js 的其他好的和坏的做法:

通用编码标准

  1. 避免魔法数字和字符串:
    • 对重复使用或具有特殊含义的值使用常量。
   // good
   const max_items = 10;

   function additem(item) {
     if (items.length < max_items) {
       items.push(item);
     }
   }

   // bad
   function additem(item) {
     if (items.length < 10) {
       items.push(item);
     }
   }
  1. 高效使用 v-for:
    • 使用 v-for 时,始终提供唯一的键来优化渲染。
   
   
{{ item.name }}
{{ item.name }}
  1. 避免内联样式:
    • 更喜欢使用 css 类而不是内联样式,以获得更好的可维护性。
   
   
{{ item.name }}
{{ item.name }}

组件实践

  1. 组件可重用性:
    • 设计可通过 props 重用和配置的组件。
   // good
   

   // bad
   
  1. 道具验证:
    • 始终使用类型和必需的属性来验证 props。
   // good
   props: {
     title: {
       type: string,
       required: true
     },
     age: {
       type: number,
       default: 0
     }
   }

   // bad
   props: {
     title: string,
     age: number
   }
  1. 避免长方法:
    • 将长方法分解为更小、更易于管理的方法。
   // good
   methods: {
     fetchdata() {
       this.fetchuserdata();
       this.fetchpostsdata();
     },
     async fetchuserdata() { ... },
     async fetchpostsdata() { ... }
   }

   // bad
   methods: {
     async fetchdata() {
       const userresponse = await fetch('api/user');
       this.user = await userresponse.json();
       const postsresponse = await fetch('api/posts');
       this.posts = await postsresponse.json();
     }
   }
  1. 避免具有副作用的计算属性:
    • 计算属性应该用于纯计算而不是副作用。
   // good
   computed: {
     fullname() {
       return `${this.firstname} ${this.lastname}`;
     }
   }

   // bad
   computed: {
     fetchdata() {
       // side effect: fetch data inside a computed property
       this.fetchuserdata();
       return this.user;
     }
   }

模板实践

  1. 使用 v-show 与 v-if:
    • 使用 v-show 来切换可见性,而无需从 dom 添加/删除元素,并在有条件渲染元素时使用 v-if。
   
   
content
content
content
  1. 避免使用大模板:
    • 保持模板干净、小;如果它们变得太大,请将它们分解成更小的组件。
   
   

   
   

状态管理实践

  1. 使用vuex进行状态管理:
    • 使用 vuex 管理多个组件的复杂状态。
   // good
   // store.js
   export default new vuex.store({
     state: { user: {} },
     mutations: {
       setuser(state, user) {
         state.user = user;
       }
     },
     actions: {
       async fetchuser({ commit }) {
         const user = await fetchuserdata();
         commit('setuser', user);
       }
     }
   });
  1. 避免组件中的直接状态突变:
    • 使用突变来修改 vuex 状态,而不是直接突变组件中的状态。
   // good
   methods: {
     updateuser() {
       this.$store.commit('setuser', newuser);
     }
   }

   // bad
   methods: {
     updateuser() {
       this.$store.state.user = newuser; // direct mutation
     }
   }

错误处理和调试

  1. 全局错误处理:
    • 使用 vue 的全局错误处理程序来捕获和处理错误。
   vue.config.errorhandler = function (err, vm, info) {
     console.error('vue error:', err);
   };
  1. 提供用户反馈:
    • 发生错误时向用户提供清晰的反馈。
   // Good
   methods: {
     async fetchData() {
       try {
         const data = await fetchData();
         this.data = data;
       } catch (error) {
         this.errorMessage = 'Failed to load data. Please try again.';
       }
     }
   }

   // Bad
   methods: {
     async fetchData() {
       try {
         this.data = await fetchData();
       } catch (error) {
         console.error('Error fetching data:', error);
       }
     }
   }

通过遵循这些额外的实践,您可以进一步提高 vue.js 应用程序的质量、可维护性和效率。

Kuwebs企业网站管理系统3.1.5 UTF8
Kuwebs企业网站管理系统3.1.5 UTF8

酷纬企业网站管理系统Kuwebs是酷纬信息开发的为企业网站提供解决方案而开发的营销型网站系统。在线留言模块、常见问题模块、友情链接模块。前台采用DIV+CSS,遵循SEO标准。 1.支持中文、英文两种版本,后台可以在不同的环境下编辑中英文。 3.程序和界面分离,提供通用的PHP标准语法字段供前台调用,可以为不同的页面设置不同的风格。 5.支持google地图生成、自定义标题、自定义关键词、自定义描

下载

相关专题

更多
css
css

css是层叠样式表,用来表现HTML或XML等文件样式的计算机语言,不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

524

2023.06.15

css居中
css居中

css居中:1、通过“margin: 0 auto; text-align: center”实现水平居中;2、通过“display:flex”实现水平居中;3、通过“display:table-cell”和“margin-left”实现居中。本专题为大家提供css居中的相关的文章、下载、课程内容,供大家免费下载体验。

268

2023.07.27

css如何插入图片
css如何插入图片

cssCSS是层叠样式表(Cascading Style Sheets)的缩写。它是一种用于描述网页或应用程序外观和样式的标记语言。CSS可以控制网页的字体、颜色、布局、大小、背景、边框等方面,使得网页的外观更加美观和易于阅读。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

761

2023.07.28

css超出显示...
css超出显示...

在CSS中,当文本内容超出容器的宽度或高度时,可以使用省略号来表示被隐藏的文本内容。本专题为大家提供css超出显示...的相关文章,相关教程,供大家免费体验。

539

2023.08.01

css字体颜色
css字体颜色

CSS中,字体颜色可以通过属性color来设置,用于控制文本的前景色,字体颜色在网页设计中起到很重要的作用,具有以下表现作用:1、提升可读性;2、强调重点信息;3、营造氛围和美感;4、用于呈现品牌标识或与品牌形象相符的风格。

761

2023.08.10

什么是css
什么是css

CSS是层叠样式表(Cascading Style Sheets)的缩写,是一种用于描述网页(或其他基于 XML 的文档)样式与布局的标记语言,CSS的作用和意义如下:1、分离样式和内容;2、页面加载速度优化;3、实现响应式设计;4、确保整个网站的风格和样式保持统一。

606

2023.08.10

css三角形怎么写
css三角形怎么写

CSS可以通过多种方式实现三角形形状,本专题为大家提供css三角形怎么写的相关教程,大家可以免费体验。

561

2023.08.21

css设置文字颜色
css设置文字颜色

CSS(层叠样式表)可以用于设置文字颜色,这样做有以下好处和优势:1、增加网页的可视化效果;2、突出显示某些重要的信息或关键字;3、增强品牌识别度;4、提高网页的可访问性;5、引起不同的情感共鸣。

397

2023.08.22

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

0

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3万人学习

CSS教程
CSS教程

共754课时 | 22.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号