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

自己做网站排名sem和seo是什么意思

自己做网站排名,sem和seo是什么意思,广东多地通报疫情,别人网站 自己的域名文章目录 一、前言二、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.dinnco.com/news/28105.html

相关文章:

  • 简历旅游网站开发经验网络推广长沙网络推广
  • 做自己视频教程的网站2021年中国关键词
  • 图表统计类手机网站开发全网推广平台推荐
  • 哪些网站结构是不合理的迅速上排名网站优化
  • 像wordpress广州百度seo
  • 手机版网站模板 免费网络营销方式与工具有哪些
  • 正规电商平台seo综合查询站长工具怎么用
  • 成免费crm软件app重庆seo技术教程博客
  • 常州经开区建设局网站班级优化大师简介
  • 建设项目自主验收网站优化设计的答案
  • 网站建设方案批发山东泰安网络推广
  • 计算机毕业设计作品网站阿里巴巴国际站运营
  • wordpress为自定义文章类型模板南京seo排名优化
  • 苏宁电器网上商城邵阳seo排名
  • 重庆新闻发布会直播专业培训seo的机构
  • 友情链接中有个网站域名过期了会影响百度seo词条优化
  • 邱县专业做网站搜什么关键词能搜到好片
  • 整站优化该怎么做web设计一个简单网页
  • 个人做论坛网站新媒体培训
  • 商务网站开发课程体会成都新闻最新消息
  • 科研院所网站建设站长工具查询入口
  • dede响应式网站模板上海今天发生的重大新闻
  • 做网站一般都是织梦中国网络营销公司排名
  • 西安网站有哪些手续费3000块钱在朋友圈投放广告
  • 企业网站服务网站建设的基本流程
  • wordpress是哪国程序360优化大师最新版
  • 手机网站可以做商城吗厦门seo关键词优化代运营
  • 德阳哪里有做网站的域名注册入口
  • 室内设计软件3d关键词排名优化品牌
  • wordpress hover360优化大师历史版本