返回顶部
首页 > 资讯 > 前端开发 > JavaScript >JavaScript实现组件化和模块化方法详解
  • 618
分享到

JavaScript实现组件化和模块化方法详解

JS组件化和模块化JS组件化JS模块化 2023-05-20 08:05:26 618人浏览 泡泡鱼
摘要

目录组件化和模块化模块化组件化Vue中的组件化组件化和模块化 为什么会有组件化和模块化?当我们的项目复杂度不断上升,项目维护成本逐渐提高之后,对于旧项目的维护就变得格外困难。前端如果

组件化和模块化

为什么会有组件化和模块化?当我们的项目复杂度不断上升,项目维护成本逐渐提高之后,对于旧项目的维护就变得格外困难。前端如果按照以前的编程方式,将许多htmljs代码都封装在同一个页面,甚至于我们大多数时候在编写html页面的时候会将同一段代码复制黏贴到不同的页面上,那么无疑对于维护者来说是一场巨大的灾难,所以组件化和模块化的出现便成为了一种必然。

组件化和模块化其实思想内核时一致的,甚至于我认为组件化是脱胎于模块化。它们二者的目的都是为了减少我们维护项目的成本,减少代码的冗余,提高代码的阅读性。

这两者让我们可以将频繁使用到的代码,复杂的页面,划分成一个个独立而又互相联系的小方块,就像积木一样,最终可以拼凑出一座更好的代码大楼。

模块化

提起前端的模块化,就离不开es6。随着ES6的出现,更多的指令,命令和功能也随之出现,我们可以编程出更友好的代码。

es6中出现了module的说法,即模块。通过将我们的js代码封装成一个个module,然后使用export和import命令,我们就可以更好地去管理我们的功能代码,将通用的代码统一封装成一个个小模块,将大型的功能代码划分成简单易懂的函数方法。

'use strict'
//导出变量
export const a = '100';  
 //导出方法
export const dogSay = function(){ 
    console.log('wang wang');
}
//导出函数
export function catSay(){
   console.log('miao miao'); 
}
// export catSay 这样也行
// 使用的地方导入
// export导出的是多个,需要解构取值
import {a,dogSay,catSay} from 'url'

正是因为ES6这一更新,便有了我们将模块一个个划分,也有了我们更好地去使用插件,封装插件的途径,当我们正确使用模块化,就可以减少代码的冗余,减少页面结构的臃肿,也更好地可以去将各种功能插件封装到项目中。

组件化

组件化的中心思想其实跟模块化是大同小异的,可以简单地认为模块化是对于我们的JS功能代码的一个说法,而组件化是对于我们html,CSS代码的一个说法,当我们的JS功能代码可以被封装成一个个小的模块后,经过不断地思考演化,就引出了组件化这一说法。

组件化对应前端三剑客中的html和css,作为一个前端开发者,如果没有组件化之前,经常能碰到的一个场景就是复制同样的html代码和js代码到不同页面上,去做这种重复而无聊的工作。

或者其实我们可以用后端提供的组件化,比如PHP,jsp中,它们可以提供一个组件化的解决方案,就是通过封装同一文件,然后php,jsp去识别读取我们页面上对应的标签。

但是这样的方案在前端后端分离开发中显得是相对麻烦而且依赖性太强了,并不能算是前端真正的组件化解决方案。

所以前端的各种框架横空出世,当然它们也是通过node等类型的一个服务端语言来实现我们的前端组件化,但是相对于php和jsp,它们显然更适合我们的前后端分离开发。

这里以Vue封装组件作为例子,通过一个简单的封装组件,我们可以清晰地看到组件是如何被封装,以及如何应用。

Vue中的组件化

Vue中我们使用emit和props完成组件的通讯。通讯也就是说我们可以传递一些参数给这个组件母版,获得一个按照我们需要生成的组件。类似于我们定义一个类,可以传递一些参数,来实例化一个独特的对象。

props

props就是当我们使用组件时,就要传递一些参数给到我们的母版,这样才能得到我们想要的组件的样式或者对应的一些功能。比如一个input,如果我们希望它是不可被输入的,那我们就可通过传递一个参数,值为false,然后props中的参数会接收到对应的值,再将它传给我们的组件中的html标签input。

emit

为什么会有emit?因为我们封装一个输入框母版之后,当我们在某一个页面使用这个母版生成的子组件并且想要添加一个@input的方法,如果直接@input=“function”,会发现是没效果的。

我们需要的应该是它的母版,在母版上的input事件绑定一个function,然后当输入触发了这个function后通过emit(声明一个函数如inputFun)发送出去,然后我们在子组件上可以接收到这个信号@inputFun=“getFun”,只要我们监听了inputFun,它就会将有输入这个信号传给我们在子组件定义的getFun。

<template>
  <div class="cat-input" :class="{ 'cat-input--suffix': showSuffix }">
    <!-- type:先判断是否有传入显示密码,控制输入框类型是文本/密码,然后是type传入的值 -->
    <input
      :type="showPassWord ? (passwordVisiable ? 'text' : 'password') : type"
      class="cat-input__inner"
      :placeholder="placeholder"
      :name="name"
      :disabled="disabled"
      :class="{ 'is-disabled': disabled }"
      :value="value"
      @input="handleinput"
    />
    <span class="cat-input__suffix" v-if="showSuffix">
      <i
        class="cat-input__icon cat-icon-circle-close"
        v-if="clearable && value"
        @click="clear"
      ></i>
      <i
        class="cat-input__icon cat-icon-view"
        :class="{ 'cat-icon-view-active': passwordVisiable }"
        v-if="showPassword"
        @click="handlepwd"
      ></i>
    </span>
  </div>
</template>
<script>
export default {
  name: "CatInput",
  props: {
    placeholder: {
      type: String,
      default: "",
    },
    type: {
      type: String,
      default: "text",
    },
    name: {
      type: String,
      default: "",
    },
    disabled: {
      type: Boolean,
      default: false,
    },
    value: {
      type: String,
      default: "",
    },
    clearable: {
      type: Boolean,
      default: false,
    },
    showPassword: {
      type: Boolean,
      default: false,
    },
  },
  data() {
    return {
      passwordVisiable: false, //控制是否显示密码
    };
  },
  methods: {
    handleinput(event) {
      //父组件在绑定v-model时,其实就绑定的input事件,因此父组件不需要再声明事件了
      this.$emit("input", event.target.value);
    },
    clear() {
      this.$emit("input", "");
    },
    handlepwd() {
      this.passwordVisiable = !this.passwordVisiable;
    },
  },
  computed: {
    //有清空/显示密码,添加类名、显示span
    showSuffix() {
      return this.clearable || this.showPassword;
    },
  },
};
</script>
// 组件需要注册才能使用,要么全局,要么在页面上局部注册。
import CatInput from "./components/input.vue";
Vue.component(CatInput.name, CatInput);
<template>
  <!-- 
  输入框需要绑定v-model,实际上是一个语法糖,等价于:
  :value="uname"
  @input="uname=$event.target.value"
 -->
  <div>
    <Cat-input
      placeholder="请输入用户名"
      type="text"
      v-model="uname"
      clearable
    ></Cat-input>
    <br />
    <Cat-input placeholder="禁用的输入框" disabled></Cat-input>
    <br />
    <Cat-input
      placeholder="请输入密码"
      v-model="upwd"
      show-password
    ></Cat-input>
  </div>
</template>
<script>
export default {
  data() {
    return {
      uname: "",
      upwd: "",
    };
  },
};
</script>
<style lang="scss" scoped>
.cat-input {
  margin-bottom: 10px;
}
</style>

到此这篇关于javascript实现组件化和模块化方法详解的文章就介绍到这了,更多相关JS组件化和模块化内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: JavaScript实现组件化和模块化方法详解

本文链接: https://lsjlt.com/news/214204.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • JavaScript实现组件化和模块化方法详解
    目录组件化和模块化模块化组件化Vue中的组件化组件化和模块化 为什么会有组件化和模块化?当我们的项目复杂度不断上升,项目维护成本逐渐提高之后,对于旧项目的维护就变得格外困难。前端如果...
    99+
    2023-05-20
    JS组件化和模块化 JS组件化 JS模块化
  • 如何通过JavaScript实现组件化和模块化
    今天小编给大家分享的是如何通过JavaScript实现组件化和模块化,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。组件化和模块化为什么会有组件化和模块化?当我们的项目复杂度不断上升,...
    99+
    2023-07-06
  • JavaScript 模块化详解
    目录前言:1.概念2.模块化的好处3.引入多个script标签后出现的问题一、CommonJS二、AMD三、CMD四、ES6模块化前言: 1.概念 将一个复杂的程序依据一...
    99+
    2024-04-02
  • JavaScript模块化:模块化的力量,打造可重用组件
    模块化是 JavaScript 应用程序开发的关键实践,它通过将代码分离成独立的模块来组织和管理代码。这种方法提供了许多优点,包括: 代码可重用性: 模块可以被其他代码组件重复使用,提高了开发效率和代码维护性。 松耦合性: 模块之间松散...
    99+
    2024-04-02
  • 详解Node.js中的模块化方法
    目录一、模块化的基本概念1、什么是模块化2、模块化规范二、Node.js 中的模块化1、Node.js 中的模块化分类2、加载模块3、向外共享模块作用域中的成员4、Node.js 中...
    99+
    2024-04-02
  • JavaScript数组实现扁平化四种方法详解
    目录1. 常规递归法2. reduce方法3. 扩展运算符实现4. split和toString共同处理数组的扁平化就是将一个嵌套多层的数组 array(嵌套可以是任何层数)转换为只...
    99+
    2022-11-13
    JS数组扁平化 JS数组
  • 详解Python模块化--模块(Modules)和包(Packages)
    目录引言Python Modules模块导入模块①导入整个模块②导入模块中的特定函数③导入模块中的所有函数给导入的模块一个别名单独运行模块加速模块加载Python Packages包引用包(Package)中的模块引...
    99+
    2022-06-02
    Python Modules模块 Packages包
  • android组件化和模块化有什么区别
    Android组件化和模块化是两个不同的概念。1. Android组件化:Android组件化是指将一个大型的Android应用拆分...
    99+
    2023-10-12
    android
  • jquery中模块化和组件化有哪些区别
    这篇文章主要介绍“jquery中模块化和组件化有哪些区别”,在日常操作中,相信很多人在jquery中模块化和组件化有哪些区别问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”jq...
    99+
    2024-04-02
  • vue中组件化和模块化有什么区别
    本教程操作环境:windows7系统、vue3版,DELL G3电脑。模块化的由来在网页开发的早期,js制作作为一种脚本语言,做一些简单的表单验证或者动画实现,代码量比较少,只要写在script标签里面就可以了随着ajax异步请求的出现,慢...
    99+
    2023-05-14
    前端 Vue.js
  • vue中组件化和模块化有哪些区别
    这篇文章主要介绍“vue中组件化和模块化有哪些区别”,在日常操作中,相信很多人在vue中组件化和模块化有哪些区别问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue中组件化和模块化有哪些区别”的疑惑有所帮助!...
    99+
    2023-07-04
  • Python模块化和第三方模块安装的方法
    这篇文章主要介绍了Python模块化和第三方模块安装的方法的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python模块化和第三方模块安装的方法文章都会有所收获,下面我们一起来看看吧。模块化编程1.什么叫模块(...
    99+
    2023-06-30
  • 详解Js模块化的作用原理和方案
    目录一、模块化概念二、模块化作用三、模块化历程1、普通写法(全局函数及变量)2、对象封装3、匿名函数方式四、模块化方案1、CommonJS2、AMD3、CMD4、ES6 module...
    99+
    2024-04-02
  • JavaScript模块化方案和工具都有哪些
    这篇文章给大家介绍JavaScript模块化方案和工具都有哪些,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。模块化是大型前端项目的必备要素。JavaScript 从诞生至今,出现过各种...
    99+
    2024-04-02
  • Vue注册模块与登录状态的持久化实现方法详解
    目录整体框架1. 前端页面授权2. 实现注册页面3. 实现登录状态的持久化优化前端整体框架 1. 前端页面授权 当我们登录网站的时候,如果没有登录,强制让用户重定向到 登录界面 在...
    99+
    2024-04-02
  • IDEA搭建Maven模块化项目的实现方法
    今天小编给大家分享的是IDEA搭建Maven模块化项目的实现方法,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。目录前言 软硬件环境项目搭建1.创建 SpringBoot 父项目2. ...
    99+
    2023-07-06
  • 使用Nodejs怎么实现模块化和事件循环
    这期内容当中小编将会给大家带来有关使用Nodejs怎么实现模块化和事件循环,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1 Node.js简介Node.js 到底是什么?开始学习的时候,对于前端的一些知识...
    99+
    2023-06-15
  • Javascript实现Vue跨组件通信的方法详解
    目录概述思路要清晰实现要迅猛测试效果优化总结概述 我们都知道。 xxx.$on可以订阅一个消息。 xxx.$emit可以发布一个消息。 xxx.$off可以取消订阅一个消息。 思路要...
    99+
    2024-04-02
  • Python实现创建模块的方法详解
    目录楔子__import__importlib.machinery通过 module 类创建模块将一个类的实例变成一个模块小结楔子 导入一个模块,我们一般都会使用 import 关键...
    99+
    2024-04-02
  • Node.js的模块化机制和Buffer对象详解
    目录一、Node.js的模块化机制1、什么是CommonJS模块规范2、CommonJS模块规范化的内容3、每个导出的模块都有一个moudle对象,该对象包含的属性有:4、使用req...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作