当前位置: 首页 > news >正文

微企帮做网站怎样申请自己的电商平台

微企帮做网站,怎样申请自己的电商平台,余姚什么网站做装修比较好,南岸网站建设文章目录 一、前言二、Metro生命周期2.1 解析(Resolution)2.2 转换(Transformation)2.3 序列化(Serialization) 三、拓展阅读 一、前言 众所周知,Metro 是 React Native 默认的 JavaScript 打包模块。对于前端项目,打包工具已有webpack(大而全&#xff…

文章目录

    • 一、前言
    • 二、Metro生命周期
      • 2.1 解析(Resolution)
      • 2.2 转换(Transformation)
      • 2.3 序列化(Serialization)
    • 三、拓展阅读

一、前言

众所周知,MetroReact Native 默认的 JavaScript 打包模块。对于前端项目,打包工具已有webpack(大而全,图片代码打包),rollup(专攻代码打包,框架场景常见)等,既然有这些打包工具为什么还要在移动端搞一个metro,其中一个原因为ram bundle,iOS采用indexed ram bundle读取一个文件效率更高,Android采用file ram bundle

二、Metro生命周期

metrobundling有三个阶段:

  • 解析(Resolution): 解析所有模块并且构建成图,有点类似于Gradle在配置阶段会将所有相互依赖的任务构建成图。
  • 转换(Transformation):转换阶段会将模块转换成目标平台能识别的格式,这一阶段执行了js编译,主流常用的js编译器为babel
  • 序列化(Serialization):最后一个阶段序列化,会将所有转换之后的模块打包成一个或者多个bundle

2.1 解析(Resolution)

在Gradle 配置阶段我们常看到assetsaidlresjava的配置。

android{...sourceSets {main {java.excludes = ['**/build/**',]srcDirs.forEach {assets.srcDirs += "$projectDir/$it/main/assets"aidl.srcDirs += "$projectDir/$it/main/aidl"res.srcDirs += "$projectDir/$it/main/res-frame-animation"res.srcDirs += "$projectDir/$it/main/res"java.srcDirs += "$projectDir/$it/main/java"}}}...
}

metro与之对应项为assetExtssourceExts

2.2 转换(Transformation)

ram bundle的启动优化中,通过getTransformOptions可以实现模块预加载,而其他的模块按需加载从而提高启动速度。

function getTransformOptions(entryPoints: $ReadOnlyArray<string>,options: {dev: boolean,hot: boolean,platform: ?string,},getDependenciesOf: (path: string) => Promise<Array<string>>,
): Promise<ExtraTransformOptions> {// ...
}type ExtraTransformOptions = {preloadedModules?: {[path: string]: true} | false,ramGroups?: Array<string>,transform?: {inlineRequires?: {blockList: {[string]: true}} | boolean,nonInlinedRequires?: $ReadOnlyArray<string>,},
};

preloadedModules中配置的模块为预加载模块,而其他的模块在ram bundle按需加载,这一块有点类似于Android multidexAndroid5.0之前可以将部分类指明到主dex,其他被分配到辅dex。在Android App的构建流程中,编译完之后还会对字节码进行混淆,这块metro也有minifierPath(默认使用metro-minify-terser)、minifierConfig。在混淆这块除了terser,metro还提供了metro-minify-uglify

2.3 序列化(Serialization)

在序列化的阶段模块需要有id以便于require导入,创建模块id的函数为createModuleIdFactory,而processModuleFilter决定了过滤掉哪些模块不进入bundle,所以通过createModuleIdFactoryprocessModuleFilter两个函数可以实现分包。

随着react-refreshreact-reconciler相继出现,react hot loader逐渐被替代,react refresh的实现与平台无关,ReactReact Native等实现react-reconciler的自定义渲染器都能使用,而且react refresh能hot的颗粒度更小。在Web平台使用react refresh 。移动平台则是React Native团队自己实现且内置到了metro打包器取名fast-refresh

三、拓展阅读

  • Recat Native Metro 官网
http://www.hengruixuexiao.com/news/45628.html

相关文章:

  • 浏览器有哪几种百度seo多少钱一个月
  • 科技微网站中国舆情在线
  • 高仿卡地亚手表网站哈尔滨seo网络推广
  • 湛江网站公司cpa推广平台
  • 网站做我女朋友数字营销软件
  • 有个找人做任务赚返佣的网站百度大数据查询怎么用
  • 微信微网站建设平台企业网站建设规划
  • 平台推广精准客源网站关键词如何优化上首页
  • 可信网站是否必须做商家推广平台有哪些
  • 360建筑网官网网址无锡seo培训
  • 做帖子的网站有哪些网站如何建立
  • 悬赏做海报的网站seo怎么发文章 seo发布工具
  • wordpress无法复制文件北京网站优化哪家好
  • 网站建设中页面云南网站建设快速优化
  • 免费域名申请网站大全下载网店推广策划书
  • 网站开发亿玛酷技术百度在线问答
  • p2p网站建设公司哪家好深圳关键词优化公司哪家好
  • wordpress建站教程主题徐州做网站的公司
  • 在线建站软件高端网站建设案例
  • 注册网站需要怎么办理百度网盘下载速度
  • ps网站切图教程b2b网站排名
  • 做第三方库网站seop
  • 惠州住房和建设局网站学前端去哪个培训机构
  • 搭建钓鱼网站教程手机优化软件哪个好
  • 网站域名不要了怎么做推广app赚佣金接单平台
  • 企业方案seo是什么职位
  • 如何做网站推广广告连云港seo优化
  • 电子商务网站建设实训展示整站优化关键词排名
  • 影院禁止18岁以下观众入内站长工具seo综合查询 分析
  • 网站草图排行榜软件