北京西站在几环校友网站建设

pingmian/2025/10/8 2:49:50/文章来源:
北京西站在几环,校友网站建设,263企业邮箱登录口,网站开发用什么网站前端工程化是使用软件工程的方法来单独解决前端的开发流程中模块化、组件化、规范化、自动化的问题,其主要目的为了提高效率和降低成本。 前端工程化实现技术栈 前端工程化实现的技术栈有很多,我们采用ES6nodejsnpmViteVUE3routerpiniaaxiosElement-plus组合来实现 ECMAScri…前端工程化是使用软件工程的方法来单独解决前端的开发流程中模块化、组件化、规范化、自动化的问题,其主要目的为了提高效率和降低成本。 前端工程化实现技术栈 前端工程化实现的技术栈有很多,我们采用ES6nodejsnpmViteVUE3routerpiniaaxiosElement-plus组合来实现 ECMAScript6 VUE3中大量使用ES6语法Nodejs 前端项目运行环境npm 依赖下载工具vite 前端项目构建工具VUE3 优秀的渐进式前端框架router 通过路由实现页面切换pinia 通过状态管理实现组件数据传递axios ajax异步请求封装技术实现前后端数据交互Element-plus 可以提供丰富的快速构建网页的组件仓库 JS模块化介绍 模块化是一种组织和管理前端代码的方式将代码拆分成小的模块单元使得代码更易于维护、扩展和复用。它包括了定义、导出、导入以及管理模块的方法和规范。前端模块化的主要优势如下 提高代码可维护性通过将代码拆分为小的模块单元使得代码结构更为清晰可读性更高便于开发者阅读和维护。提高代码可复用性通过将重复使用的代码变成可复用的模块减少代码重复率降低开发成本。提高代码可扩展性通过模块化来实现代码的松耦合便于更改和替换模块从而方便地扩展功能。 目前前端模块化有多种规范和实现包括 CommonJS、AMD 和 ES6 模块化。ES6 模块化是 JavaScript 语言的模块标准使用 import 和 export 关键字来实现模块的导入和导出。现在大部分浏览器都已经原生支持 ES6 模块化因此它成为了最为广泛使用的前端模块化标准. ES6模块化的几种暴露和导入方式 分别导出统一导出默认导出 ES6中无论以何种方式导出,导出的都是一个对象,导出的内容都可以理解为是向这个对象中添加属性或者方法 分别导出 module.js 向外分别暴露成员 //1.分别暴露 // 模块想对外导出,添加export关键字即可! // 导出一个变量 export const PI 3.14 // 导出一个函数 export function sum(a, b) {return a b; } // 导出一个类 export class Person {constructor(name, age) {this.name name;this.age age;}sayHello() {console.log(Hello, my name is ${this.name}, Im ${this.age} years old.);} } app.js 导入module.js中的成员 /* *代表module.js中的所有成员m1代表所有成员所属的对象 */ import * as m1 from ./module.js // 使用暴露的属性 console.log(m1.PI) // 调用暴露的方法 let result m1.sum(10,20) console.log(result) // 使用暴露的Person类 let person new m1.Person(张三,10) person.sayHello() index.html作为程序启动的入口  导入 app.js !-- 导入JS文件 添加typemodule 属性,否则不支持ES6的模块化 -- script src./app.js typemodule / 统一导出 module.js向外统一导出成员 //2.统一暴露 // 模块想对外导出,export统一暴露想暴露的内容! // 定义一个常量 const PI 3.14 // 定义一个函数 function sum(a, b) {return a b; } // 定义一个类 class Person {constructor(name, age) {this.name name;this.age age;}sayHello() {console.log(Hello, my name is ${this.name}, Im ${this.age} years old.);} } // 统一对外导出(暴露) export {PI,sum,Person } app.js导入module.js中的成员 /* {}中导入要使用的来自于module.js中的成员{}中导入的名称要和module.js中导出的一致,也可以在此处起别名{}中如果定义了别名,那么在当前模块中就只能使用别名{}中导入成员的顺序可以不是暴露的顺序一个模块中可以同时有多个import多个import可以导入多个不同的模块,也可以是同一个模块 */ //import {PI ,Person ,sum } from ./module.js //import {PI as pi,Person as People,sum as add} from ./module.js import {PI ,Person ,sum,PI as pi,Person as People,sum as add} from ./module.js // 使用暴露的属性 console.log(PI) console.log(pi) // 调用暴露的方法 let result1 sum(10,20) console.log(result1) let result2 add(10,20) console.log(result2) // 使用暴露的Person类 let person1 new Person(张三,10) person1.sayHello() let person2 new People(李四,11) person2.sayHello() 默认导出 modules混合向外导出 // 3默认和混合暴露 /* 默认暴露语法 export default sum默认暴露相当于是在暴露的对象中增加了一个名字为default的属性三种暴露方式可以在一个module中混合使用*/ export const PI 3.14 // 导出一个函数 function sum(a, b) {return a b; } // 导出一个类 class Person {constructor(name, age) {this.name name;this.age age;}sayHello() {console.log(Hello, my name is ${this.name}, Im ${this.age} years old.);} }// 导出默认 export default sum // 统一导出 export {Person } app.js 的default和其他导入写法混用 /* *代表module.js中的所有成员m1代表所有成员所属的对象 */ import * as m1 from ./module.js import {default as add} from ./module.js // 用的少 import add2 from ./module.js // 等效于 import {default as add2} from ./module.js// 调用暴露的方法 let result m1.default(10,20) console.log(result) let result2 add(10,20) console.log(result2) let result3 add2(10,20) console.log(result3)// 引入其他方式暴露的内容 import {PI,Person} from ./module.js // 使用暴露的Person类 let person new Person(张三,10) person.sayHello() // 使用暴露的属性 console.log(PI) npm 原npm地址 C:\Users\nanchengyu\AppData\Roaming\npm 安装依赖 (查看所有依赖地址 https://www.npmjs.com ) npm报错 解决链接方式一即可解决 这个报错存在于之前安装过npm而有没有将全局的下载的依赖从原来C盘更改到其他盘的情况 npm安装报错npm ERR! code EPERM npm ERR! syscall mkdir npm ERR! path C:\Program Files\nodejs\node_ca...-CSDN博客 body div idapph1 v-textmessagehello vue/h1h1{{message}}/h1buttonchange/button /divscript//引入vue.js const app Vue.createApp({setup(){//定义数据 以变量 /对象形式let message hello//在return中返回的变量/方法才能够和HTML元素关联return{message,headline}})//将app对象挂载在指定元素上被挂载的元素内部就可以通过vue框架实现数据渲染了app.mount(#app)/script /body Vite 工程化管理项目 类似于ant design pro ViteVue3项目的目录结构 1.下面是 Vite 项目结构和入口的详细说明 public/ 目录用于存放一些公共资源如 HTML 文件、图像、字体等这些资源会被直接复制到构建出的目标目录中。src/ 目录存放项目的源代码包括 JavaScript、CSS、Vue 组件、图像和字体等资源。在开发过程中这些文件会被 Vite 实时编译和处理并在浏览器中进行实时预览和调试。以下是src内部划分建议 assets/ 目录用于存放一些项目中用到的静态资源如图片、字体、样式文件等。components/ 目录用于存放组件相关的文件。组件是代码复用的一种方式用于抽象出一个可复用的 UI 部件方便在不同的场景中进行重复使用。layouts/ 目录用于存放布局组件的文件。布局组件通常负责整个应用程序的整体布局如头部、底部、导航菜单等。pages/ 目录用于存放页面级别的组件文件通常是路由对应的组件文件。在这个目录下可以创建对应的文件夹用于存储不同的页面组件。plugins/ 目录用于存放 Vite 插件相关的文件可以按需加载不同的插件来实现不同的功能如自动化测试、代码压缩等。router/ 目录用于存放 Vue.js 的路由配置文件负责管理视图和 URL 之间的映射关系方便实现页面之间的跳转和数据传递。store/ 目录用于存放 Vuex 状态管理相关的文件负责管理应用程序中的数据和状态方便统一管理和共享数据提高开发效率。utils/ 目录用于存放一些通用的工具函数如日期处理函数、字符串操作函数等。 vite.config.js 文件Vite 的配置文件可以通过该文件配置项目的参数、插件、打包优化等。该文件可以使用 CommonJS 或 ES6 模块的语法进行配置。package.json 文件标准的 Node.js 项目配置文件包含了项目的基本信息和依赖关系。其中可以通过 scripts 字段定义几个命令如 dev、build、serve 等用于启动开发、构建和启动本地服务器等操作。Vite 项目的入口为 src/main.js 文件这是 Vue.js 应用程序的启动文件也是整个前端应用程序的入口文件。在该文件中通常会引入 Vue.js 及其相关插件和组件同时会创建 Vue 实例挂载到 HTML 页面上指定的 DOM 元素中。 2.vite的运行界面 在安装了 Vite 的项目中可以在 npm scripts 中使用 vite 可执行文件或者直接使用 npx vite 运行它。下面是通过脚手架创建的 Vite 项目中默认的 npm scripts(package.json) {scripts: {dev: vite, // 启动开发服务器别名vite devvite servebuild: vite build, // 为生产环境构建产物preview: vite preview // 本地预览生产构建产物} } 运行设置端口号(vite.config.js) //修改vite项目配置文件 vite.config.js export default defineConfig({plugins: [vue()],server:{port:3000} }) 一个.vue文件构成一个页面组件 vue各组件关联关系 vue-css 导入css方式App.vue 在.vue文件中的style标签中直接编写将css样式保存在独立的css文件中导入 scriptimport 文件路径/scriptstyleimport 文件路径 /style 如果某个样式要在所有的.vue中生效可以在main.js中导入 vue各小知识点 1. 插值表达式 1.1. {{}}里面放入属性名即可 templatediv!--插值表达式可以调用韩叔叔将函数的返回值渲染到指定页面 --msg的为{{msg}}msg的值为{{getMsg()}}!--插值表达式支持一些常见的运算符 --年龄{{age}},是否成年{{age 18?是否}}!-- 插值表达式支持对象调用一些api --{{bee.split().reverse().join()}}/div /template 2. v-*** vue指令 1. 命令必须依赖标签在开始标签中使用 2. v-text 不识别html结构中的文本 v-html识别文本中的html代码的命令 script setup // 命令支持字符串模块let msg hello vuelet hello hello// 命令支持常见的运算符let msg2 ${hello} nanchengyu//命令支持常见的api调用let bee bee /script templatedivh1 v-textmsg /h1h1 v-textmsg2 /h1h1 v-text你好 ${msg} /h1h1 v-textbee.split().reverse().join(-) /h1h1 v-htmlfontMsg /h1/div /template 3.属性渲染命令 v-bind 将数据绑定到元素的属性上 v-bind:属性属性名 简写 :属性属性名 script setuplet imgUrl 图片或其他链接const data{logo:链接同上可以是本地或者网络连接name:nanchengyuurl:https://www.yuque.com//nanchengcyu} /script templatedivimg v-bind:srcimgUrla v-bind:hrefdata.urlimg v-bind:srcdata.logo v-bind:titledata.name/a/div /template 4. v-on绑定事件 v-on:事件名称“函数名” v-on:事件名可以简写为 事件名 script setupfunction fun1(){alert(nanchengyu)}let count 1 /script templatedivbutton v-on:clickfun1()hello/button!--事件内联处理器 --button v-on:clickcounthello/button!--事件内联修饰符 once事件只绑定一次--button v-on:click.oncecount/button/div /template 3. 响应式数据 ref函数 适合单个变量 在script中需要.value属性修饰 在template中不需要可以直接调用函数中的方法即可 reactive函数 适合对象 在script和template中都不需要可以直接调用对象.属性名即可 script setupimport {ref,reactive} from vuelet counter ref(1)function fun1(){counter.value}let personreactive({name:,age:10})function incrA(){person.age}/script templatedivbutton clickfun1()/buttonbutton click counter.value/buttonhrbutton clickincrAge/button/div /template 4. 条件渲染 v-if表达式数据为true 则当前元素会渲染进入dom树 v-else自动和前一个v-if做取反操作 v-show数据为true元素则展示在页面上否则不展示 v-if 数据为false时元素则不再dom树中了 v-show数据为false时元素仍然在dom树中通过display的css样式控制元素隐藏 script typemodule setupimport {ref} from vuelet awesome ref(true) /scripttemplatedivh1 v-ifawesomeVue is awesome!/h1h1 v-elseOh no /h1button clickawesome !awesomeToggle/button/div /template style scoped /style 5. 列表渲染 script typemodule setupimport {reactive} from vuelet items reactive([{id:2,name:薯片}{id:3,name:西红柿}]) /scripttemplatedivulli v-foritem in items{{item.message}}/li/ul/div /template style scoped /style 6. 双向绑定 单向绑定 v-bind 响应式数据发生变化时更新dom树 用户的操作如果造成页面内容的变化不会影响响应式数据 双向绑定 v-model 页面上的数据由于用户的操作造成了变化也会同步修改对应的响应式数据 双向绑定一般都用于表单标签 双向绑定也有人称呼为收集表单信息的命令 v-model:value数据 双向绑定 但是一般 value可以省略 v-model script typemodule setup//引入模块import { reactive,ref} from vue let hbs ref([]); //装爱好的值let user reactive({username:null,password:null,introduce:null,pro:null}) function login(){alert(hbs.value);alert(JSON.stringify(user));}function clearx(){//user {};// 这中写法会将数据变成非响应的,应该是user.usernameuser.usernameuser.passworduser.introduceuser.prohbs.value.splice(0,hbs.value.length);;} /scripttemplatediv账号 input typetext placeholder请输入账号 v-modeluser.username br密码 input typetext placeholder请输入账号 v-modeluser.password br爱好 吃 input typecheckbox namehbs v-modelhbs value吃 喝 input typecheckbox namehbs v-modelhbs value喝玩 input typecheckbox namehbs v-modelhbs value玩乐 input typecheckbox namehbs v-modelhbs value乐br简介:textarea v-modeluser.introduce/textareabr籍贯:select v-modeluser.prooption value1黑/optionoption value2吉/optionoption value3辽/optionoption value4京/optionoption value5津/optionoption value6冀/option/select brbutton clicklogin()登录/button button clickclearx()重置/buttonhr显示爱好:{{ hbs }}hr显示用户信息:{{ user }}/div /template style scoped /style 7. vue生命周期 路由router 路由传参 路由守卫 Vue3数据交互axios promiss 解决传统的回调函数 普通函数: 正常调用的函数,一般函数执行完毕后才会继续执行下一行代码 回调函数: 一些特殊的函数,表示未来才会执行的一些功能,后续代码不会等待该函数执行完毕就开始执行了 script// 设置一个2000毫秒后会执行一次的定时任务setTimeout(function (){console.log(setTimeout invoked)},2000)console.log(other code processon) /script 在前端开发中回调函数类似于Java中的接口interface或者匿名类anonymous class。回调函数是一种通过将函数作为参数传递给其他函数并在某个事件发生或异步操作完成时执行的机制。这种模式常用于处理用户输入、异步请求、定时器等情况。 script/* 1.实例化promise对象,并且执行(类似Java创建线程对象,并且start)参数: resolve,reject随意命名,但是一般这么叫!参数: resolve,reject分别处理成功和失败的两个函数! 成功resolve(结果) 失败reject(结果)参数: 在function中调用这里两个方法,那么promise会处于两个不同的状态状态: promise有三个状态pending 正在运行resolved 内部调用了resolve方法rejected 内部调用了reject方法参数: 在第二步回调函数中就可以获取对应的结果 */let promise new Promise(function(resolve,reject){console.log(promise do some code ... ...)//resolve(promise success)reject(promise fail)})console.log(other code1111 invoked)//2.获取回调函数结果 then在这里会等待promise中的运行结果,但是不会阻塞代码继续运行promise.then(function(value){console.log(promise中执行了resolve:${value})},function(error){console.log(promise中执行了reject:${error})})// 3 其他代码执行 console.log(other code2222 invoked)/scriptscriptlet promise new Promise(function(resolve,reject){console.log(promise do some code ... ...)// 故意响应一个异常对象throw new Error(error message)})console.log(other code1111 invoked)/* then中的reject()的对应方法可以在产生异常时执行,接收到的就是异常中的提示信息then中可以只留一个resolve()的对应方法,reject()方法可以用后续的catch替换then中的reject对应的回调函数被后续的catch替换后,catch中接收的数据是一个异常对象*/promise.then(function(resolveValue){console.log(promise中执行了resolve:${resolveValue})}//,//function(rejectValue){console.log(promise中执行了reject:${rejectValue})}).catch(function(error){console.log(error)} )console.log(other code2222 invoked) /script Axios介绍 ajax AJAX Asynchronous JavaScript and XML异步的 JavaScript 和 XML。AJAX 不是新的编程语言而是一种使用现有标准的新方法。AJAX 最大的优点是在不重新加载整个页面的情况下可以与服务器交换数据并更新部分网页内容。AJAX 不需要任何浏览器插件但需要用户允许 JavaScript 在浏览器上执行。XMLHttpRequest 只是实现 Ajax 的一种方式。 pinia 处理多数据共享

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

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

相关文章

自己做的网站视频播放不了中国上市网络公司排名

https://www.cnblogs.com/qiankun-site/p/5886673.html 1、此监听器主要用于解决java.beans.Introspector导致的内存泄漏的问题 2、此监听器应该配置在web.xml中与Spring相关监听器中的第一个位置(也要在ContextLoaderListener的前面)3、JDK中的java.beans.Introspector类的用途…

广州市公司网站建设足球比赛直播平台app

一、Mysql基本介绍 当谈论MySQL时,通常指的是一个流行的开源关系型数据库管理系统(RDBMS)。MySQL是由瑞典的开发者在1995年创建的,后来被Sun Microsystems收购,最终成为Oracle Corporation的一部分。以下是关于MySQL的…

建站成本深圳网络营销推广案例

apple mac 下使用机械键盘的办法,键盘映射工具软件,apple mac Mechanical keyboard 想在苹果电脑 mac 系统下使用 机械键盘,大部分机械键盘不是为mac设计的,所以需要用软件做一下键盘映射。 推荐使用这个:https://pqrs…

手机网站首页怎么做教育类网站 前置审批

#-*- coding: utf-8 -*-""" 思路 核心:每次落稳之后截图,根据截图算出棋子的坐标和下一个块顶面的中点坐标,根据两个点的距离乘以一个时间系数获得长按的时间识别棋子:靠棋子的颜色来识别位置,通过截图…

网页制作培训网站辽宁注册公司网站

当玩家或用户在启动某些游戏和应用程序时,可能会遭遇到一个系统错误提示:“由于找不到xinput1_3.dll,无法继续执行代码l”。这种情况通常指出系统中DirectX组件存在问题。以下我们将介绍几种常用的解决方法,并提供详细的操作步骤。 一.找不到…

合肥专业做淘宝网站建设wordpress 下拉菜单插件

Spring 是线程安全的,支持多线程并发调用。但在某种特殊情况下,使用 BeanFactory 的 getBean 方法,我成功拿到了未经初始化的 Bean(是BUG,亦或是出于某种原因考虑的特性?)。 一、获取到的 Bean 为什么未初始化? 通过 getBean 获取到未经过初始化的 Bean 需要满足如下…

福州网站建设招商娄底企业网站建设公司

索引的设计原则 索引覆盖是什么: 索引(在MySQL中也叫做“键(key)”) 是存储引擎用于快速找到记录的一种数据结构。这是索引的基本功能。 索引对于良好的性能非常关键。尤其是当表中的数据量越来越大时,索引…

在线免费视频网站推广平面广告设计用什么软件

学习目的: (1) 熟悉SPI接口和它的读写时序; (2) 复习Verilog仿真语句中的$readmemb命令和$display命令; (3) 掌握SPI接口写时序操作的硬件语言描述流程(本例仅…

python 做网站开发吗做网站如何选择数据源

出现原因: 此处的offset的值表示的是盒子模型经过计算后的实际偏移量,通常是margin及定位偏移量之和(flex布局导致的偏移也会计算在内)。在此处也无需消除。 解决办法: 父元素设置宽高。设置margin为负数&#xff0…

做租房信息网站淘宝怎么优化关键词排名

区别: 1,Resource(JSR-250标准注解,推荐使用它来代替Spring专有的Autowired注解) 2,Spring 不但支持自己定义的Autowired注解,还支持几个由JSR-250规范定义的注解,它们分别是Resourc…

广西建设厅考试网站博客网站开发报告文库

OpenCV7-copyTo截取ROI copyTo截取感兴趣区域 copyTo截取感兴趣区域 有时候,我们只对一幅图像中的部分区域感兴趣,而原图像又十分大,如果带着非感兴趣区域一次处理,就会对程序的内存造成负担,因此我们希望从原始图像中…

两学一做学习网站更多标签的适用场景

如果你的操作系统是 Windows,而你想要连接 Linux 服务器相互传送文件,那么你需要一个简称 SSH 的 Secure Shell 软件。实际上,SSH 是一个网络协议,它允许你通过网络连接到 Linux 和 Unix 服务器。SSH 使用公钥加密来认证远程的计算…

代理注册seo是什么职业

问题描述   JSON (JavaScript Object Notation) 是一种轻量级的数据交换格式,可以用来描述半结构化的数据。JSON 格式中的基本单元是值 (value),出于简化的目的本题只涉及 2 种类型的值:   * 字符串 (string):字符串是由双引号…

山西省建设执业资格注册中心网站软件制作公司排名

1.介绍和基础操作 Python中的元组(Tuple)是不可变有序序列,可以容纳任意数据类型(包括数字、字符串、布尔型、列表、字典等)的元素,通常用圆括号() 包裹。与列表(List)类似&#xff…

专业网站设计服务在线咨询义乌企业网站

FROM : http://blog.ityao.com/archives/581 如果想用Flash/Flex监听浏览器的关闭事件,可以通过JavaScript的window.onbeforeunload事件进行监听然后JS调用Flash中的函数。在swf所在页面的JavaScript中添加如下代码JS中代码:(这里设定swf文件…

破解网站后台账号密码上海做网站的公司多少钱

也许有些人是学C出身,对于Java几乎不了解。一时心血来潮想学学android开发,于是下载了Eclipse,安装了SDK,有模有样的学习起来。也许是懒惰了,对于java一直总是提不起精神。于是确定使用DreamweaverJquery mobilePhoneg…

比较好的公文写作网站wordpress菜单怎么添加次级菜单

函数的三种调用方式:1、函数作为表达式中的一项出现在表达式中,例“zmax(x,y)”;2、函数作为一个单独的语句,例“printf("%d",a)”;3、函数作为调用另一个函数时的实参,例“printf("%d"…

专门做pp他的网站WordPress十大免费CMS主题

矩阵键盘 矩阵键盘是一种常用于电子设备中的输入设备,其原理是利用行和列的交叉点来识别按键输入。矩阵键盘通常由多个按键排列成行和列的形式组成,通过按下某个按键可以在对应的行和列交叉点上产生电路连接。 在矩阵键盘中,每个按键都被安排…

网站建设需要学代码吗企业网站建设规划方案

#Dubbo# 文章内容 Dubbo服务导出基本原理分析Dubbo服务注册流程源码分析Dubbo服务暴露流程源码分析服务导出的入口方法为ServiceBean.export(),此方法会调用ServiceConfig.export()方法,进行真正的服务导出。 1. 服务导出大概原理 服务导出的入口方法为ServiceBean.export…

如何自己做购物网站免费建站平台

文章目录1. 题目2. 解题1. 题目 现在,我们用一些方块来堆砌一个金字塔。 每个方块用仅包含一个字母的字符串表示。 使用三元组表示金字塔的堆砌规则如下: 对于三元组(A, B, C) ,“C”为顶层方块,方块“A”、“B”分别作为方块“…