vue前端标准

news2024/9/22 5:38:34

此文档的目的是让前端和产品、服务端开发,相互之间形成一种默契。

比如一些通用设计,不需要产品去说明,我们默认怎么做。

以及,我们开发之间的默契。

期盼大家的补充

开发原则:

感谢各位开发大佬共建原则,以兼顾平衡效率、质量,保证了代码的健壮性,实现了易扩展、易维护的软件工程,确保了代码的生命周期long long time.

  1. 开发规范学习材料 参考链接
    1.代码未动,思想先行
    a. 避免代码过度设计,但编程思想需要考虑全面。强烈建议,在各位置引入 @todo机制,简单备注,未来可能出现也可能不出现,可能出现时,代码该如何改动。

  2. 测试驱动开发Tdd
    不用具体实施vue-test jest的代码来写单侧用例,但必须用脑图规划单侧用例以驱动开发,为评估影响面和稳定性提供保证。

面向过程、面向对象

  1. 面向过程

    面向过程就是分析出解决问题所需要的步骤,然后用函数把这些步骤一步一步实现,使用的时候再一个一个的依次调用就可以了。
    总结:按照步骤编程 (函数和变量)

  2. 面向对象

    面向对象是把事务分解成为一个个对象,然后由对象之间分工与合作。
    总结:将需求分析出一个一个的对象,然后在分析出对象中的属性和方法,最后按照步骤编程(方法和属性)

  3. 面向过程与面向对象对比
    在这里插入图片描述

  4. 应用场景

    前端更偏向使用面向过程。后端更偏向使用面向对象。

    前端的业务,往往是一个过程流,更偏向使用面向过程!

    面向对象思想,在前端的应用领域,多是开发实现复杂的工具类,和库。同时组件化思想也和面向对象思想有异曲同工之妙,面向组件化开发。

css

  • CSS 属性很多,难记
  • CSS 属性之间互相影响,难以完全掌握
  • 写出的CSS 代码臃肿、难维护、难复用
  • 业务和ui设计变动频繁,极容易越写越乱。

css原则:

  1. 注意抽离全局样式,尤其是在写css之前,开发者必须先关注全局样式设计,再自己写。(日常开发中,太多开发者各自写各自的,随着业务变动的增长,css中开始逐渐重置着样式相互覆盖,相互提示权重的混乱想象,直到最后难以维护(这里的难以维护,是值,整体网站ui的一致性被破坏。该了一个地方的字体,发现另外一个地方的字体大小不一致了。例如表格的鉴于,同一个网站,两个表格的样式能有细微的差别,这种差别不应该存在的!)

  2. 样式的层级嵌套过深,书写顺序随意,不尊重盒模型,导致渲染性能逐渐增加。
    为什么很少关注css优化?
    浏览器的渲染能力太强大,业务不复杂,觉得不管怎样都能修改和维护。所以就不关注,从而导致实际项目中,经常出现样式不一致的问题,也都是针对性改改就过去了。
    在业务复杂,一个产品支持多个业务,或者开发组件库。css的管理和开发规范,还是要重视的。

共建

举例说明:

例如在下图的需求中,我们通过CDN方式引入了外部sdk(不支持npm引入),这种情况下考略到性能问题!

我们需要做一个延时加载,并且在用户空窗期预加载。

但在未来存在的的某种场景下,这个动态资源是某个页面渲染的前置条件。考虑到这种情况,我们如果提前做了。就出现两种情况,未来压根没出现造成代码冗余,现在就开发,过度设计降低了当下的开发效率!

所以,我们需要考虑到这种情况。构建 @todo 注释,表明未来可能出现的情况,以及可能怎么做,需要怎么做。

放在最后,我们定期全局搜索,@todo 对整个项目,未来需要做可能做的事情,有个整体把控。在这种todo真正出现时,做到心中有数,而不是盲目乱拆代码。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1546023.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

STM32 ESP8266模块的曲折探索

这是本文的配套资料,最终工程请参考 新_ESP8266资料\stm32f103成功移植的项目 【免费】stm32f103c8t6esp8266资料资源-CSDN文库 一、等到了ready 产品参数 我使用的是ai-thinker的esp8266-01s,以下为产品规格书 引脚定义: 依据引脚定义&…

docker安装redis 6.2.7 并 远程连接

阿里云ecs服务器,docker安装redis 6.2.7 并 远程连接 文章目录 阿里云ecs服务器,docker安装redis 6.2.7 并 远程连接1. 拉取redis镜像2. 查看是否下载成功3. 挂载配置文件4. 下载reids配置文件(redis.conf)5. docker创建redis容器6. 查看redis容器运行状…

JL-34 超声波气象站 可集成多要素 集成度高、颜值高、免安装、免布线

产品概述 超声波气象站是我公司结合多年气象产品开发经验,根据现场实际情况开发的一款多功能自动气象站。该产品集温度、湿度、气压、风速、风向、雨量、大气压力、颗粒物和噪声等要素为一体,该系列产品集成度高、颜值高、免安装、免布线。 功能特点 …

038—pandas 重采样线性插补

前言 在数据处理时,由于采集数据量有限,或者采集数据粒度过小,经常需要对数据重采样。在本例中,我们将实现一个类型超分辨率的操作。 思路: 首先将原始数据长度扩展为 3 倍,可以使用 loc[] 方法对索引扩…

54、Qt/对话框、事件机制相关学习20240325

一、完善对话框,点击登录按钮,如果账号和密码匹配,则弹出信息对话框,给出提示”登录成功“,提供一个Ok按钮,用户点击Ok后,关闭登录界面,跳转到其他界面 如果账号和密码不匹配&#…

android h5理财(记账)管理系统eclipse开发mysql数据库编程服务端java计算机程序设计

一、源码特点 android h5理财管理系统是一套完善的WEBandroid设计系统,对理解JSP java,安卓app编程开发语言有帮助(系统采用web服务端APP端 综合模式进行设计开发),系统具有完整的源代码和数据库,系统主要…

TCP与UDP:传输层协议对比

🤍 前端开发工程师、技术日更博主、已过CET6 🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 🍚 蓝桥云课签约作者、上架课程《Vue.js 和 E…

VMware中添加使用ubuntu

提示:本文为学习记录,若有错误,请联系作者,谦虚受教。 文章目录 前言一、ubuntu安装二、下载vmwareTool三、解压文件四、解决联网失败五、linux常用命令总结 前言 打破舒适圈 一、ubuntu安装 Vmware安装流程 二、下载vmwareToo…

编程语言|C语言——C语言实现玫瑰花(情人节)

1.说明 在古希腊神话中,玫瑰花集爱与美于一身,既是美神的化身,又溶进了爱神的血液,所以它所代表的含义是爱情。 我们应该用玫瑰花来表达我们的爱意,但是好多的恋人都是因为异地而没有办法去买一束新鲜的玫瑰去送给自己…

Fast-Planner(三)详解后端B-Spline曲线优化

本文上接Fast-Planner的B-spline曲线生成详解,介绍B-spline曲线优化。如有问题,欢迎各位大佬评论指出,带着我一起进步。 三、B样条优化 初始化获得的B样条曲线只是达到了可达性检测,本章介绍为得到更加光滑安全的轨迹&#xff0…

训练自己的分类数据集

文章目录 1.数据集准备2. 数据集划分3.设计模型进行训练1. 随便乱写的网络2. 借鉴优秀的网络模型(MobileNetV3) 分析:练习: 1.数据集准备 准备你要进行分类的数据集,可以自己拍摄,可以网上进行爬取。 将不…

pdf压缩文件怎么压缩最小?一键压缩PDF

pdf文件压缩是为了减小文件大小,以便更轻松地共享、传输和存储文件,通过压缩pdf文件,可以减少文件占用的存储空间,加快文件的上传和下载速度,并节省带宽和存储成本;在本教程中,我们将介绍一些有效的方法来最…

人工智能三剑客NumPy、pandas、matplotlib和Jupyter四者之间的关系

NumPy 主要用途:NumPy(Numerical Python的缩写)主要用于处理大型多维数组和矩阵的科学计算。它提供了一个高性能的多维数组对象,以及用于数组操作的工具。与其他三者的联系:NumPy是pandas和matplotlib的基础库之一。许…

10.IO流(一)

文章目录 IO流一、File1.创建对象1.1 创建File类的对象1.2 注意1.3 绝对路径、相对路径 2.常用方法1:判断文件类型、获取文件信息3.常用方法2:创建文件、删除文件3.1 File类创建文件的功能3.2 File类删除文件的功能 4.常用方法3:遍历文件夹4.1 File类提供的遍历文件夹的功能4.2…

【JAVA】数据类型与变量(主要学习与c语言不同之处)

✅作者简介:大家好,我是橘橙黄又青,一个想要与大家共同进步的男人😉😉 🍎个人主页:橘橙黄又青-CSDN博客 目标: 1. 字面常量 2. 数据类型 3. 变量 1.字面常量 在上节课 Hello…

paramiko,一个强大的 Python 库!

更多资料获取 📚 个人网站:ipengtao.com 大家好,今天为大家分享一个强大的 Python 库 - paramiko。 Github地址:https://github.com/paramiko/paramiko 在网络编程中,远程操作是一项非常常见的需求,特别是…

QT 界面2.1

#include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {this->setWindowIcon(QIcon(":/Logo/1bc87d9b4c1ea878d5e0845257a06f7f (1).jpg")); // 图标this->setWindowTitle(&…

环境变量与进程详解

文章目录 1.进程的优先级1.1 查看优先级1.2 调制优先级 2.环境变量2.1 命令行参数2.2 环境变量 3.程序的地址空间3.1 为什么要有地址空间?3.2 linux的大O(1)调度算法 4.进程创建5.进程中止5.1 进程的退出码(错误码)5.2 进程终止的最优写法&am…

苍穹外卖Day07——总结7

前期文章 文章标题地址苍穹外卖Day01——总结1https://lushimeng.blog.csdn.net/article/details/135466359苍穹外卖Day02——总结2https://lushimeng.blog.csdn.net/article/details/135484126苍穹外卖Day03——总结3https://blog.csdn.net/qq_43751200/article/details/1363…

Data.olllo解密:秒数转换为日期格式的神奇技能!

引言: 时间是数据世界中不可或缺的一环,而将秒数转换为易读的日期格式往往是数据处理中的一大挑战。但是,有了Data.olllo,这一任务将变得异常简单! 功能介绍: Data.olllo的秒数转换功能可以让您轻松地将秒…