这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助

对vue项目来说,组件是构成项目的基本单元,为了方便理解,这里定义两类组件:页面组件,功能组件。
为什么需要划分这两类组件是从组件复用来考虑的。

我们知道在复杂应用中,页面状态管理早已不是早期的简单的子父组件的传值,兄弟组件传值。而当我们寻求到vuex这种状态管理来处理组件间状态管理的时候,我们同样也对使用vuex的组件失去了复用的可能。

为什么失去了复用的可能?
我们知道是用第三方状态管理就意味着状态丢给了第三方,而我们的组件依赖第三方状态管理的时候,单个组件就不足以仅把组件复用,还必须根据该组件对于的状态进行第三方状态管理的配置。同时我们可能还要对各种状态是做什么的了如指掌,这和写一个该组件的成本没什么差别(可能比写一份该组件的成本更高)。

所以,对于该类使用或者可能使用第三方库的组件划分为页面组件,而剩下的和第三方库无依赖关系的组件划分为功能组件。
从而我们可以理解为,页面组件是无法复用的组件,功能组件是可以复用的组件。

如何定义他们

最先对页面组件的定义仅仅是整张页面的统筹,页面组件也是由一个个功能组件堆叠而成的,比如element-ui这样的组件库,他们的组件都可以称之为功能组件。而我们所写的页面,引入了element-ui中的各种组件堆出了一张管理系统的页面,就是页面组件。我们通常会在页面组件中发送数据请求,根据接口返回数据,处理为可用数据,然后将数据分发给不同功能组件。同样,页面组件也会接受功能组件返回值,根据返回值做不同的处理(或请求数据,或修改数据)

而对功能组件的定义为,他的展示只受父组件通过props组件传值过来的数据影响,他的所有状态均为内部私有,与外部组件的交互有vue提供的props以及事件分发vm.$emit()。因为只有这也组件才能保证其完整的内部状态,在复用时不受其他因素的影响。

如何划分他们

划分页面组件最简单的方式是由路由划分,每一个路由对应一个页面组件。
功能组件的划分需要对页面组件的功能进行分析分类。功能组件的划分可能根据不同人的理解各不相同,但是原则只有一个:

功能组件应该类似面向对象编程一样,一个功能组件应该只是完成一个功能。

拿当你看见这篇博文时页面的布局来举个例子:

页面组件就是当前你看见的这个网页地址的完整显示,他将包含几个功能组件

功能组件可能有以下几个:
1. 文章组件,可能需要的props的值为:标题,时间,内容 (文章内容显示)
2. 个人信息组件:可能需要的props的值为:头像等个人信息 (个人信息显示)
3. 列表组件:可能需要的props的值为:列表名,列表list (右下角的最新文章,文章存档,热门文章等显示)
4. 评论组件: 可能需要的props的值为:头像,名称,时间,内容。
5. 按钮组件: 页面中的各种按钮,比如左边的点赞分享按钮,可能需要的props为两张小图片,一张正常显示,一张移入显示

在谈谈自己对页面组件的理解

自己对页面组件的理解仅仅是各种功能组件的整合,就和我们写以前项目中使用js调用各种库一样,通过这些库写出了各种效果。我们可能通过jquery的ajax发送一个请求,请求回来一个分也数据,我们把分页数据处理,把数据条数传给了一个分页插件,然后分页插件帮我们渲染出了分页器。我们可能把请求回来的列表内容传递给了一个自己封装的表格渲染插件,表格渲染插件帮我们渲染出了我们想要的表格数据并且显示在了页面上面。而页面组件就担任这这个js所做的功能,请求数据,分发数据,接受插件的回调,在请求数据,在分发数据
而页面组件也是一样,请求处理数据,分发数据给对应组件的props,接受某些组件的vm.$emit()传回来的值,在请求处理数据,修改组件的props的值进行传递

由上面一系列类比,其实组件就好比或者说就是插件,或者面向对象的写法。思想上面对组件的划分就和对功能的封装。组件留的props就是对接口的定义。本质上没区别的。

本文转载于:

https://blog.csdn.net/stopllL/article/details/79473357

如果对您有所帮助,欢迎您点个关注,我会定时更新技术文档,大家一起讨论学习,一起进步。

记录--vue组件划分的思考的更多相关文章

  1. Vue组件使用基础

    这篇博文用来记录 .vue 组件的使用方法. 可以把组件代码按照 template.style.script 的拆分方式,放置到对应的 .vue 文件中. 模板(template).初始数据(data ...

  2. 重新思考 Vue 组件的定义

    重新总结组件的定义 这是官方对组件的定义:组件允许我们将 UI 划分为独立的.可重用的部分,并且可以对每个部分进行单独的思考.在实际应用中,组件常常被组织成层层嵌套的树状结构. 对于 Vue 开发经验 ...

  3. vue 组件发布记录

    好久没做独立的 vue 组件了,最近突然想把一个常用的 vue 组件打成一个 npm 包,方便使用.好久不用,发现已经忘记环境怎么搭建.翻看以前的组件,才慢慢回想起来,中间还出现些错误.在这记录下开发 ...

  4. 4.VUE前端框架学习记录四:Vue组件化编码2

    VUE前端框架学习记录四:Vue组件化编码2文字信息没办法描述清楚,主要看编码Demo里面,有附带完整的代码下载地址,有需要的同学到脑图里面自取.脑图地址http://naotu.baidu.com/ ...

  5. 3.VUE前端框架学习记录三:Vue组件化编码1

    VUE前端框架学习记录三:Vue组件化编码1文字信息没办法描述清楚,主要看编码Demo里面,有附带完整的代码下载地址,有需要的同学到脑图里面自取.脑图地址http://naotu.baidu.com/ ...

  6. vue学习记录⑤(组件通信-父与子)

    今天我们看一下组件通信. 经过前面几篇文章,我们已经可以构建出完整的单个组件,并利用路由使其串联起来访问了. 但这明显还是不够的.一个页面不可能就是个单组件,一般是由多个组件合成的.正因为如此,组件之 ...

  7. vue组件库(一):前期准备工作

    前言 将近期项目内自行开发一个vue组件,做个总结,记录下自己的思维过程~~~ 正文 接到这个任务后,还是要做些准备工作的. 主要内容如下: 1.优化下所在团队前端开发流程 服务器搭建gitlab,采 ...

  8. Vue 组件设计

    Vue 组件设计 Vue 作为 MVVM 框架一员,不管是写业务还是基础服务,都少不了书写组件.本文总结一下书写业务组件的一些心得. 为什么要写组件? 我们知道,只要是组件,就需要在引用的时候与 vi ...

  9. vue组件化开发实践

    前言 公司目前制作一个H5活动,特别是有一定统一结构的活动,都要码一个重复的轮子.后来接到一个基于模板的活动设计系统的需求,便有了一下的内容.首先会对使用Vue进行开发的一些前期需要的技术储备进行简单 ...

  10. Vue.js 学习笔记之四:Vue 组件基础

    到目前为止,这个系列的笔记所展示的都是一些极为简单的单页面 Web 应用程序,并且页面上通常只有几个简单的交互元素.但在实际生产环境中,Web 应用程序的用户界面往往是由多个复杂的页面共同组成的.这时 ...

随机推荐

  1. layui弹出层:使用icon图标小结

    转自:https://www.cnblogs.com/webSnow/p/15470350.html layui弹出层:使用icon图标小结 Layui 踩坑篇layui的弹框插件layer中,有很多 ...

  2. 从零开始的微信小程序入门教程(四),理解小程序事件与冒泡机制

    壹 ❀ 引 我在之前初识WXML与数据绑定两篇文章中,介绍了小程序静态模板与样式相关概念,以及小程序几种常用数据绑定方式,在知道这些知识后,我们可以写一些不算复杂的小程序页面,并能将一些自定义的数据渲 ...

  3. NC201613 Jelly

    题目链接 题目 题目描述 Nancy喜欢吃果冻! Nancy钻进了一个 \(n \times n \times n\) 的果冻里,她想从(1,1,1)一路上.下.左.右.前.后六个方向吃到(n,n,n ...

  4. XTW100编程器在Win10下的安装

    XTW100 这是一个淘宝上卖得很多的经典编程器, 用于写入24和25系列的存储芯片. 最初使用的是stm32f103c8t6, 因为f103价格飞涨, 市面上大都换成国产的兼容mcu了, 软件和使用 ...

  5. 使用RBF神经网络实现函数逼近

    python实现的RBF神经网络见:基于tensorflow的RBF神经网络案例 1 一元函数逼近 1.1 待逼近的函数 1.2代码 %%%%%%%%%%一元函数逼近%%%%%%%%%% clear, ...

  6. Spring Boot图书管理系统项目实战-1.系统功能和架构介绍

    导航: next:2.项目搭建 1.项目源码 需要源码的朋友,请捐赠任意金额后留下邮箱发送:) 2.项目背景 自己闲着没事写的,供初学spring boot和在校大学生毕业设计学习交流.大神请忽略:) ...

  7. Google C++ 风格指南记录

    最近在看谷歌的 C++ 风格指南发现了一些有意思的知识点,遂记录下 1. 第六章第二小节介绍了右值引用 只在定义移动构造函数与移动赋值操作时使用右值引用. 不要使用 std::forward. 定义: ...

  8. 教你如何判断Java代码中异步操作是否完成

    本文分享自华为云社区<java代码实现异步返回结果如何判断异步执行完成>,作者: 皮牙子抓饭. 在许多应用程序中,我们经常使用异步操作来提高性能和响应度.在Java中,我们可以使用多线程或 ...

  9. 详解SSL证书系列(1)什么是SSL证书?

    你一定遇到过这种情况,打开一个网站,浏览器弹出警告"您与此网站之间建立的连接不安全.由于此连接不安全,因此信息(如密码或信用卡)不会安全地发送到此网站,并且可能被其他人截获或看到" ...

  10. ASP.NET Core 微信支付(三)【查询订单 APIV3】

    官方参考资料 查询订单 理论实战 官方提供两种查询订单的方式,一种是根据商户自己生成的订单号查询,一种方式是根据微信生成的订单号查询.而我使用的就是第一种方式. 调用微信支付的查询订单,需要生成签名, ...