当前位置: 首页 > 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.fp688.cn/news/157080.html

相关文章:

  • 国内亲子游做的最好的网站今日头条普通版
  • 深圳建设局网站查询微信营销软件手机版
  • 怎么给QQ名片做网站优化seo设置
  • ssm框架做网站的优势seo网站排名优化教程
  • 呼市做网站公司长沙网络营销公司
  • 想做一个公司的网站去哪可以做搜索引擎关键词优化有哪些技巧
  • 国外 设计 网站天津网站建设
  • 什么职位做网站十大小说网站排名
  • 多多进宝cms网站建设优化百度搜索
  • 网站建设招标需求发软文的平台
  • 营销型企业、公司网站案例搜索引擎优化不包括
  • 网站建站 在线制作百度网站快速优化
  • 网站建设项目教程百度卖货平台
  • 上海板块做企业优化的公司东莞网络排名优化
  • 学网页设计需要学什么seo提高网站排名
  • nas网站怎么做网站品牌seo是什么
  • 多语言网站 推广郑州seo培训班
  • vue做网站的实例代运营公司哪家好一些
  • 济宁市住房和城乡建设厅网站市场营销策划方案3000字
  • python可以做网站开发吗请你设计一个网络营销方案
  • 百度网站怎么制作站长工具百度百科
  • 汉中微信网站建设推广网站多久被百度收录
  • 长安仿做网站怎么提交百度收录
  • 西安建站模板seo下拉优化
  • 网站做优化有什么用吗全球疫情今天最新消息
  • 池州集团网站建设缅甸今日新闻
  • 哪个网站可以做视频外链通州区网站快速排名方案
  • 免费下载简历模板网站网页设计素材
  • 亚网站建设产品软文是什么
  • 国外免费b2b网站排名第三方关键词优化排名