皮皮网
皮皮网

【和源码头】【goim源码解读】【无忧源码会员】pwa 源码

来源:spring注解源码入口 发表时间:2024-12-22 16:29:10

1.web应用系统开发?
2.一次vue-cli4项目升级到vite的经历

pwa 源码

web应用系统开发?

       1.渐进式Web应用程序(PWA)

       通过利用技术进步参与开发移动站点和本机应用程序的企业可以从渐进式Web应用程序中受益。到目前为止,这是年最热门的Web开发趋势。它鼓励万维网为用户提供更好的浏览体验。

       渐进式Web应用程序是一般的Web应用程序,在用户看来像移动应用程序,和源码头但实际上它们是行为类似于移动应用程序的网页和网站。PWA致力于为所有设备上所有平台的用户提供类似本机的体验。

       根据最近的一项研究,就互联网使用和网站浏览而言,移动技术在其他设备上占据主导地位。不仅如此,使用移动应用程序和移动浏览器之间的差距还很大。可以估算一下,我们可以说移动应用程序占用户在其小工具上花费的总时间的%以上。

       实施PWA的一些知名公司包括阿里巴巴,Twitter,维珍美国航空,福布斯等。使用PWA的显着优势是,您的品牌对于具有更强身份的受众更加可见。PWA中使用的流行技术是Angular,Polymer和React。

2.人工智能与机器人

       如您所知,企业跨不同时区工作并在各个大洲提供代表,这使得客户支持服务既复杂又昂贵,尤其是考虑到x7模式时。但是,随着最近的发展,企业已转向自动化的即时客户端支持。

       你们大多数人可能已经发现,聊天机器人可以使用人工智能和机器学习的概念。在未来的几年中,聊天机器人和机器学习的概念将比以往更加全面,尤其是对于Web设计和开发行业。

       有多项调查表明,聊天机器人用于为客户查询提供快速响应和解决方案。AI执行人类的认知功能,例如学习,分析信息,收集数据,理解情绪以及解决具有挑战性的问题的能力,这使聊天机器人成为Web开发的完美补充。

       Facebook,Microsoft,goim源码解读Twitter,Google和Amazon等主要供应商都在人工智能以及机器学习方面进行了大量投资。以下可用于为您的网站构建机器人的技术包括Facebook Bot Engine,Microsoft Bot Framework和Dialog flow。

3.加速的移动页面(AMP)

       Google不断采用新技术来改善用户的移动浏览体验。Google在年向公众推出了加速的移动页面项目,该项目现已发展成为自己的新技术。

       AWP的目的是减少网页的加载时间或构建可在所有设备上快速加载且完美运行的网站。AMP页面的加载时间被认为是两秒钟,而常规网页可能需要长达秒的加载时间。

       与标准网页相比,加速的网页具有明显的优势,因为当您的网页加载速度更快时,用户将很高兴浏览您的网站。此外,它将有助于提高您的Web应用程序的搜索引擎排名。

       要将AMP技术引入您的网站,您将必须使用AMP HTML开放源代码框架。Google首次提出这个概念时,就提供了有关如何构建AMP网页的详细文档。

4.单页申请

       单页应用程序完全基于JavaScript,是可在所有设备上正常运行的Web应用程序。它们不仅可以提高网站性能,还可以通过使用JavaScript加载所有内容来消除重新加载页面的需要。

       大多数公司使用单页应用程序,因为与加载多页相关的额外等待时间。诚然,与多页Web应用程序相比,该页面可能需要花费更多的时间来加载,但是,如果考虑到用户在网站上的整个旅程的总时间,那么放弃渲染多个页面所节省的时间就变得很重要。这也使构建响应式网站变得更加容易。

       SPA的示例包括Gmail,Facebook和GitHub。SPA中使用的技术包括React和Angular框架,使其成为混合应用程序的理想选择。

5.语音搜索优化

       语音搜索已经对Web开发产生了重大影响,使其成为年成功的趋势之一,因此我们简直不能忽略它。根据Gartner的报告,由于智能扬声器的兴起,到年,将有%以上的无忧源码会员搜索完成而无需在屏幕上键入任何内容。

       即使在年,我们也会获得带有Google助手按钮的设备,从而使用户更轻松地在其设备上打开语音识别。因此,语音搜索在Web开发中达到顶峰还为时不远。到年,我们可以假设英国的语音商务销售额可以增长到亿美元,在美国达到亿美元。

       考虑到多个研究报告和市场的实际情况,我们可以说语音搜索优化是不断增长的Web开发趋势之一,不容忽视。有可能,它将尽快成为您的SEO或技术策略的一部分。

       要对您的站点实施语音搜索优化,可以使用Web搜索API,该API分为两个部分-语音识别和语音合成。语音识别使您的网站能够识别用户的声音,然后响应他们的查询,而语音合成使脚本能够读取文本内容。

6.运动界面

       Motion UI是为交互式Web设计提供动态图形和动画的东西。简而言之,通过提供优雅的界面,即使使用简约的网站,它也可以使您的Web应用程序设计与众不同。而且,如果您进行适当的研究和实施,它可以为您的网站的转化率带来奇迹。

       Motion UI是年最好的网络趋势之一,因为它为您提供了一种吸引访问者注意力的简单解决方案。使用Motion UI库,您可以合并动画图表,背景动画,悬停和醒目的标题。

       使用Motion UI元素不仅可以使您的网站脱颖而出,还可以通过鼓励积极的用户互动和改善网站可用性来增强用户参与度。对于开发人员来说,这是一个额外的优势,因为他们有多种选择来制作功能强大的出色站点。

7.自动化测试

       我们知道自动化测试已经存在了几年,但是其中的最新创新使其再次进入了趋势列表。从单元测试到Web应用程序的跨浏览器测试,Web开发测试中发生了许多变化。例如,以前您必须在系统上设置一个环境来执行Web应用程序的emacs源码阅读测试,但是现在不一样了。

       市场上提供了用于Web应用程序测试的多种扩展程序和API,使开发人员可以轻松地测试其网站。例如,Chrome,WordPress扩展程序和Screenshot API附带的LambdaTest,使用户无需编写任何外部脚本即可测试其网页。

       最大,最受信任的自动化测试平台是LambdaTest,BrowserStack或跨浏览器测试,甚至一些大型企业都在使用它们。

8. JavaScript

       JavaScript是最流行的编程语言之一,随着时间的推移不断发展,并为开发人员提供了新的功能。JavaScript的高级框架,设计和库已经证明,它在市场上可以提供很多东西。

       这就是为什么它仍处于Web开发的十大趋势之列的原因。曾经有一段时间人们因为JavaScript与某些浏览器不兼容而放弃使用JavaScript并改用纯HTML和CSS。但是,随着对JS的浏览器支持的赶超,越来越多的Web开发人员正在使用基于JS的框架和库来构建其网站。

       JavaScript用于开发动态Web应用程序。它为开发人员构建网站提供了灵活性,挑战性和强大功能的全新体验。借助JavaScript,开发人员能够构建精确,健壮和响应迅速的网站。使它在其他语言中脱颖而出的一些广泛功能是回调和闭包。

       不仅如此,基于JavaScript的框架和库,尤其是Angular和React,为Web开发人员提供了更多功能。因此,可以说在未来几年中,基于JavaScript的框架将推动Web开发。

9.区块链技术

       随着整个年比特币的流行,你们中的许多人可能已经对区块链及其对整个Web开发行业的影响有所了解。

       据信,到年,区块链将给网络行业带来根本性的变化。区块链是一种开放式分布式账本,以消除联络需求而提供安全和受保护的在线交易而闻名。它使用普通数据存储来帮助个人将数据存储在世界各地。内核源码数

       由于保护水平高,许多跨国银行和组织都计划投资于区块链。此外,它还有助于降低金融业务成本,降低交易结算的频率并改善由透明记录支持的现金流。

.物联网

       根据Statista的报告,相信年已连接设备的数量将超过亿。物联网设备的巨大增长将直接影响Web开发,因为公司将从台式机或笔记本电脑控制此类设备。

       物联网将为企业带来多种机遇,并使他们能够以高精度提高效率。而且,为了向客户提供更好的服务,将设备与网站集成已经变得至关重要。开发这些设备的不仅是开发人员,还包括开发人员。我们还将平等参与开发使用,分析和显示设备数据的应用程序。

       物联网还将带来很多挑战,尤其是在数据安全方面,因此开发人员将面临很多挑战。尽管只有少数网站或Web应用程序正在使用IoT集成,但在未来几天中,几乎每个网站都将开始集成它以改善客户体验。

结论

       Web开发是一个永远不会淘汰的领域。实际上,随着新技术的出现,它将随着时间的推移不断发展和变化。同样,开发人员在使用这些技术方面也越来越先进,因为它允许他们以更好的方式构建应用程序或网站。

一次vue-cli4项目升级到vite的经历

       背景

       使用vue-cli4的项目,业务写多了之后开发运行和打包都慢了很多,为了提升开发体验以及更新团队技术框架,需要升级到更高级的脚手架上,两种方案:一是升级到vue-cli5,二是升级到最新的vite。

       其中第一种方案升级简单,经过实验,打包的速度不升反慢,这可能和项目中的有依赖以及业务代码有关。

       第二种方案升级vite,经过可行性调查,升级到vite的成功率非常高,最后决定从vue-cli4升级到vite,这是一个高风险高回报的事情,因为尽管市面上已存在很多升级成功的案列,但是每个项目都不一样,我们的项目也很庞大,依赖很多,并没有%升级成功的把握。而升级成功的回报也很显而易见,开发环境几乎秒运行,开发体验得到了显著提升。

升级前后对比

       ||vue-cli4|vite||---|---|---||开发启动时间|ms|ms||生产打包时间|s|s||打包体积|.6MB|.6MB||运行期间同一代码改动编译时间|ms|瞬时|

       生产环境打包时间可能和我们项目中用到了太多vite插件有关系,但开发环境的提升非常显著。

项目状况

       项目中用到的Vue2,VueCli版本:4.5.,版本更新时间为.5.8,vueCli4的最后版本为4.5.(.3.),依赖的webpack版本为^4.0.0

       组件库使用vant,依赖Less预处理器,通过vue.config.js配置设置了less主题色,在webpack仅支持less-loader@5版本以及对应的less版本

       业务css预处理器为stylus:"^0..5",对应stylus-loader:"^3.0.2"

       进行了多页打包(MPA)

       使用了workbox-webpack-plugin插件配置了PWA:WorkboxWebpackPlugin

       配置了多个路径映射(alias别名)

       指定了文件输出路径以及hash配置

       生产环境下关闭productionSourceMap以及css的sourceMap提升打包速度

       proxy开启多个代理

       用到了.env文件中的环境变量

       按照开发规范忽略部分文件后缀以及index.js

       移除了preload脚本

期望结果

       可以使用vite进行开发和打包

       仍保留webpack打包功能(因为项目太大,不能保证升级到vite后会不会有问题,所以仍希望webpack原本功能正常运行)

准备工作

       升级Node版本,vite只支持node及以上,建议升级到v以上。

       安装pnpm工具,pnpm作为更好的npm依赖管理工具,是目前npm和yarn的最好替代品,且有些依赖包使用npm安装时会有异常,使用pnpm安装可解决:pnpm

       小项目尝试一键转换升级:wp2vite、webpack-to-vite,这两个工具都提供了一键将webpack项目转成vite的能力,但对于大中型项目,并不可靠。

开始行动1.安装必要依赖pnpm?add?vite-plugin-env-compatible?vite-plugin-html?vite?vite-plugin-vue2?--dev

       vite-plugin-vue2是处理vue2版本代码的插件,如果项目中是vue3,安装的依赖有所不同,请参考webpack-to-vite

2.复制html到根目录,并修改 注意是复制,并只改动复制后的html,这样才不会破坏原有webpack功能。

       修改复制后的html,增加对应的js文件引用,注意type属性不能少!

<!--?忽略一些代码?--><body><div?id="app"></div>++?<script?type="module"?src="/src/main.js"></script>?++</body>

       多页打包(MPA),其他页面的html同样操作,不同html引入对应的js即可。

3.新增vite.config.js文件,开始迁移最重要的配置部分

       空配置如下:

import?{ ?defineConfig?}?from?'vite'export?default?defineConfig({ })4.修改环境变量

       环境变量主要面临两个问题:

       要兼容webpack和vite的环境变量用法

       解决方法:使用vite插件vite-plugin-env-compatible,让vite中可以使用webpack中读取环境变量的方式,再配合envPrefix配置,让vite可以读取到VUE_APP_开头的环境变量:

?pnpm?add?vite-plugin-env-compatible?-D?import?{ ?defineConfig?}?from?'vite'?import?envCompatible?from?'vite-plugin-env-compatible'?export?default?defineConfig({ plugins:?[?envCompatible()],envPrefix:?['VUE_APP_']?//?很重要?})?//?mian.js测试?console.log(process.env.VUE_APP_UNION_STATS)?console.log(import.meta.env.VUE_APP_UNION_STATS)

       两个打印都得到了正确的结果,注意:vite中默认只能读取到VITE_开头的环境变量,如果不配置envPrefix,则会导致第二个打印为undefind。

       vite.config.js中不能读取到环境变量

       vite.config.js是无法直接通过import.meta.env和process.env获取环境变量的,我们需要通过vite的loadEnv获取。

       我们需要将vite.config.js的导出对象改为函数:

?import?{ ?defineConfig,loadEnv?}?from?'vite'?export?default?({ ?mode?})?=>?{ ?const?isPro?=?mode?===?'production'?//?我们可以通过mode直接判断当前是不是生产环境,注意mode可以在运行指令中指定:`vite?build?--mode?master`,如果没有指定,那默认打包就是production?function?getEnv(key)?{ ?//?定义获取环境变量的方法?return?loadEnv(mode,?process.cwd(),'')[key]?//?第三个参数非常重要,下面有详解?}?return?defineConfig({ ?base:?getEnv('VUE_APP_PUBLICPATH'),?//?读取环境变量?//?...忽略其他代码?})?})

       loadEnv有三个参数,前两个参数基本固定不变,而第三个参数默认情况下是不需要传的,只有在配置了envPrefix项,读取非VITE_开头的变量时才需要,在loadEnv源码中我们可以看到,第三个参数是prefixes:string|string[]='VITE_',也就是环境变量的前缀,默认是VITE_。

       如果你的项目和我一样,读取了VUE_APP_PUBLICPATH这样非VITE_开头环境变量,就在loadEnv的第三个参数传递空字符串即可,这样就能读取到所有的环境变量了。

5.兼容commonjs代码

       项目中有用到commonjs规范的依赖,比如letmd5=require('js-md5').create(),webpack是基于node开发的,支持require语法,在打包的时候webpack也会正确处理这部分代码,但在vite中不会,所以需要将这部分代码改成importmd5from'js-md5'

       项目开发环境下,一些node_modules中的包也会存在commonjs的代码,我们可以通过vite的插件?vite-plugin-commonjs来实现这部分代码的转化,保证开发环境的正常运行。

pnpm?add?@originjs/vite-plugin-commonjs?--dev//?vite.config.js?忽略其他代码import?{ ?viteCommonjs?}?from?'@originjs/vite-plugin-commonjs'export?default?({ ?mode?})?=>?{ return?defineConfig({ plugins:?[//?...viteCommonjs()?//?兼容vite中的cjs导入语法]})})6.解决css预处理的问题

       vite内置了对主流css预处理器的支持(sass/less/stylus),项目使用预处理器时,只需要安装对应预处理依赖即可:

#?.scss?and?.sasspnpm?add?sass?-D#?.lesspnpm?add?stylus?-D#?.styl?and?.styluspnpm?add?stylus?-D

       比较巧的是,我们项目中用到的Stylus的@import别名的语法和vite冲突,@import'~@/public/stylus/mixins'这样的代码是会报错,一开始我找到了插件,可以帮助我们解决这个问题:vite-plugin-stylus-alias,但是都后面打包的时候发现这个插件有副作用,后面采取了其他方法解决。

<!--?忽略一些代码?--><body><div?id="app"></div>++?<script?type="module"?src="/src/main.js"></script>?++</body>0<!--?忽略一些代码?--><body><div?id="app"></div>++?<script?type="module"?src="/src/main.js"></script>?++</body>1

       使用这个插件会导致无法生成sourcemap文件,在打包的时候可以看到警告:Sourcemapislikelytobeincorrect:aplugin(vite-plugin-stylus-alias)wasusedtotransformfiles,butdidn'tgenerateasourcemapforthetransformation.Consulttheplugindocumentationforhelp,鉴于插件作者已经很久没有更新,建议能改成相对路径还是直接改,如果引用地方较多,可以定义文件为全局styl文件最新解决方案:一般出现这个报错是因为插件使用了vite的transformapi转换代码,但是return值缺失导致,解决方法:复制插件代码到项目中,在插件transform函数return的结果中,返回map:null,然后再vite.config.js中引用项目中修改后的插件,即可完美解决,如下:文末解决bug有细说

<!--?忽略一些代码?--><body><div?id="app"></div>++?<script?type="module"?src="/src/main.js"></script>?++</body>2

       定义stylus全局文件

<!--?忽略一些代码?--><body><div?id="app"></div>++?<script?type="module"?src="/src/main.js"></script>?++</body>3

       这里需要注意,官方文档中css-preprocessoroptions写的是使用文件名拓展名作为key,stylus的文件拓展名是styl,但是我使用了stylus作为key并不会有问题,相反使用styl作为key则不生效了,后续这个地方可以留意一下。

       在vite源码中,stylus和styl都进行了判断,理论上都可以使用,但目前测试的结果就是styl作为key不生效,可能源码中其他地方还能找到原因。

7.组件库按需导入和定制主题

       我们项目中用到的组件库是Vant2,该组件库依赖Less,以及通过配置文件来定制组件的主题,在配置中我们需要进行修改:

       vue-cli中的主题配置部分如下:

<!--?忽略一些代码?--><body><div?id="app"></div>++?<script?type="module"?src="/src/main.js"></script>?++</body>4

       vite中主题配置部分如下:

<!--?忽略一些代码?--><body><div?id="app"></div>++?<script?type="module"?src="/src/main.js"></script>?++</body>5

       按需导入项目中按需导入vant组件库,组件可以成功导入,但是组件的样式缺失了,这是因为在webpack中,babel-plugin-import插件帮我们实现了组件的样式导入,在vite中使用?vite-plugin-style-import插件帮我们实现这个功能,不仅vant组件库,其他诸如element、antv等组件库也可以使用这个插件进行按需导入:

<!--?忽略一些代码?--><body><div?id="app"></div>++?<script?type="module"?src="/src/main.js"></script>?++</body>6<!--?忽略一些代码?--><body><div?id="app"></div>++?<script?type="module"?src="/src/main.js"></script>?++</body>.修改alias别名配置,以及忽略文件后缀

       vite配置别名的方法和vue-cli有所不同,且没有默认的别名,都需要通过配置实现,且vite默认不能忽略文件后缀导入,我们也需要通过修改配置来实现:

<!--?忽略一些代码?--><body><div?id="app"></div>++?<script?type="module"?src="/src/main.js"></script>?++</body>8

       需要注意extensions配置的顺序,从左到右进行匹配,如果存在同名但类型不同的文件,很可能得到期望外的结果,比如同目录下存在index.js和index.vue,按上面的顺序,import'./index?会优先匹配到index.js文件。这种情况建议补全后缀进行导入。

9.配置前端跨域

       vite配置跨域和webpack也有出入,需要修改配置

<!--?忽略一些代码?--><body><div?id="app"></div>++?<script?type="module"?src="/src/main.js"></script>?++</body>9

       以上就是几种常见的跨域配置方式,webpack中的devServer改为了server,webpack的proxy中的pathRewrite改成了rewrite,并且类型成为了函数,在函数中返回请求的路径即可。

.多页打包以及打包的其他配置

       vite在build.rollupOptions配置多页打包,参考rollupOptions,其他配置参考文档

import?{ ?defineConfig?}?from?'vite'export?default?defineConfig({ }).配置运行路径

       base是指项目运行在服务器的哪个路径下,一般通过从环境变量中动态获取。

import?{ ?defineConfig?}?from?'vite'export?default?defineConfig({ }).配置EsLint

       vite中使用vite-plugin-eslint插件实现eslint的检查功能,安装过程中发现vite-plugin-eslint@1.4.0会报错,安装1.3.0版本即可。

import?{ ?defineConfig?}?from?'vite'export?default?defineConfig({ })2import?{ ?defineConfig?}?from?'vite'export?default?defineConfig({ }).使用插件@vitejs/plugin-legacy兼容低版本浏览器

       plugin-legacy文档

import?{ ?defineConfig?}?from?'vite'export?default?defineConfig({ }).配置运行指令import?{ ?defineConfig?}?from?'vite'export?default?defineConfig({ })5

       可以在指令中声明mode环境,这个mode在vite.config.js中可以得到,具体可以参考前面4.修改环境变量

       保存运行指令npmrunserve开发环境已经可以跑起来了,但是vite的特性是你用到的页面才会进行打包,其他页面没有进行访问,是不会打包的,所以需要进行打包才能知道其他地方改造会不会有问题,打包如果有报错,再解决报错即可。

.解决报错

       globalisnotdefined

       这个错误是在node_modules/buffer/index.js?v=ea7文件中抛出的,我查看了yarn.lock文件,依赖路径为多个vue-cli插件>webpack@4.0.0>node-libs-browser?>buffer

       这个是依赖的问题,第一删除node_modules重新安装依赖。第二更换npm工具为pnpm重装依赖,如果仍不行,建议不建议webpack,删除掉webpack相关依赖。

       网上还有一种做法是:在window对象上挂载global对象,可作为备选方案。

import?{ ?defineConfig?}?from?'vite'export?default?defineConfig({ })6

       @import'~@vant/icons/src/encode-woff2.less';报错

       这个错误是vant组件库中的icon组件抛出的,vite默认不能使用别名,我们在前面配置了别名,但是配置的是~@指向项目中的src目录,这样vant组件库的这个文件引用就找不到了。

       issuesvant

       解决方法:针对vant的这个文件,做一个别名,放到第一位,优先进行匹配:

import?{ ?defineConfig?}?from?'vite'export?default?defineConfig({ })7

       运行vitebuild,css产生了一些警告。

       警告分为两种,一是css中的属性拼写错误,诸如:color写成了colo,background写成了backgrounc,属于语法错误,根据警告提示搜索对应样式进行修改即可。

       二是一些语法正确,但还不清楚为什么压缩时提示了警告:比如stylus修改scoped样式用的>>>语法,以及background?rgba(0,0,0,0.5)提示Unexpected"rgba("。

       Thepackagemayhaveincorrectmain/module/exportsspecifiedinitspackage.json

       这个错误是通过npminstall后运行vite指令报错的,用yarn安装一直很正常,原因是node_modules的某个包的package.json定义的main入口路径错了,所以找不到模块导入。

       解决方法:针对这个模块,定义别名,指向正确的入口:

import?{ ?defineConfig?}?from?'vite'export?default?defineConfig({ })8

       打包后导入函数定义别名后,调用函数报错

       import*asminByfrom'lodash.minby'代码报错了,而且只有在生产环境下才产生。

       解决方法:暂时去掉别名,这应该和lodash的导出方式modules.export在vite中转化成ES语法的过程有关系。

       importminByfrom'lodash.minby'

       requireisnotdefine,通过require导入资源报错

       前面在步骤5已经用了插件vite-plugin-commonjs转化common.js的代码了,require理应不会报错。

       但是require导入资源算是webpack的功能,和js代码不一样,所以导入资源的代码都要进行修改:

       require('./images/logo.png')改成importlogofrom'./images/logo.png'

       这样的修改可以兼容webpack和vite,这是在现有项目中,改动的地方会达到上百处,非常麻烦。

相关栏目:探索