1.hybrid是什么,为何使用hybrid呢?

  1. 概念:

    • hybrid就是前端和客户端的混合开发
    • 需要前端开发人员和客户端开发人员配合完成
    • 某些环节也可能会涉及到server端
    • 大前端:网页、APP、前端和server端交互的过程
  2. 存在价值:
    • 可以快速迭代更新【关键】,无需APP审核(hybrid技术可以一天上线多次)
    • 体验流畅(和Native开发的体验基本类似)
    • 减少开发和沟通成本,双端公用一套代码
  3. webview:
    • 是APP中的一个组价(App可以有Webview,也可以么有)
    • 主要用于加载H5页面,是一个小型的浏览器内核
  4. file:// 协议
    • file协议: 本地文件,快
    • http(s): 网络加载、慢
    • 扩展知识:Web标准都有哪些呢?

2.hybrid的具体实现流程?

2.1 使用场景

  1. 不是所有场景都适合使用hybrid
  2. 使用NA: 体验要求极致,变化不频繁(如头条的首页)
  3. 使用hybrid:体验要求高,变化频繁(如头条的新闻详情页面)
  4. 使用H5: 体验无要求,不常用(如举报、反馈等页面)

2.2 具体实现

  1. 前端做好静态页面(HTML,CSS,JS),将文件交给客户端
  2. 客户端拿到前端静态页面,以文件形式存储在APP中
  3. 客户端在一个Webview中
  4. 使用file协议加载本地静态文件

3.介绍一下hybrid更新和上线的流程?

3.1 优点

  1. 用户体验更好,跟NA体验基本一致
  2. 可以快速迭代,无需app审核 【关键】

3.2 缺点:

  1. 开发成本高:联调、测试、查bug都比较麻烦
  2. 运维成本高。(平台维护)

3.3 适用场景:

  1. hybrid:产品的稳定功能,用户体验高,迭代频繁
  2. H5:单词的运营活动(如XX红包),或不常用的功能

4.前端JS和客户端如何通讯?

  1. 类似于JSONP的数据请求方式
  2. schema协议的简介和使用
  3. 通讯的基本形式:调用能力,传递参数监听回调
  4. 对schema协议的理解和使用
  5. 调用schema代码的封装
  6. 内置上线的好处:更快、更安全

【前端知识体系-JS相关】对移动端和Hybrid开发的理解?的更多相关文章

  1. 【前端知识体系-JS相关】JS基础知识总结

    1 变量类型和计算 1.1 值类型和引用类型的区别? 值类型:每个变量都会存储各自的值.不会相互影响 引用类型:不同变量的指针执行了同一个对象(数组,对象,函数) 1.2 typeof可以及检测的数据 ...

  2. 【前端知识体系-JS相关】ES6专题系列总结

    1.如何搭建ES6的webpack开发环境? 安装Node环境 node -v // 10.14.1 安装NPM环境 npm -v // 6.4.1 安装babel npm install @babe ...

  3. 【前端知识体系-JS相关】JS-Web-API总结

    2.1 DOM操作 2.1.1 DOM的本质是什么? <!-- DOM树:二叉树 --> /* <?xml version="1.0" encoding=&quo ...

  4. 【前端知识体系-JS相关】深入理解JavaScript异步和单线程

    1. 为什么JavaScript是单线程? JavaScript语言的一大特点就是单线程,也就是说,同一个时间只能做一件事.那么,为什么JavaScript不能有多个线程呢?这样能提高效率啊. Jav ...

  5. 【前端知识体系-JS相关】深入理解MVVM和VUE

    1. v-bind和v-model的区别? v-bind用来绑定数据和属性以及表达式,缩写为':' v-model使用在表单中,实现双向数据绑定的,在表单元素外使用不起作用 2. Vue 中三要素的是 ...

  6. 【前端知识体系-JS相关】组件化和React

    1. 说一下使用jQuery和使用框架的区别? 数据和视图的分离,(jQuery数据和视图混在一起,代码耦合)-------开放封闭原则 以数据驱动视图(只关注数据变化,DOM操作被封装) 2.说一下 ...

  7. 【前端知识体系-JS相关】10分钟搞定JavaScript正则表达式高频考点

    1.正则表达式基础 1.1 创建正则表达式 1.1.1 使用一个正则表达式字面量 const regex = /^[a-zA-Z]+[0-9]*\W?_$/gi; 1.1.2 调用RegExp对象的构 ...

  8. 【前端知识体系-JS相关】你真的了解JavaScript编译解析的流程吗?

    1. JS编译解析的流程 1.1 JS运行分三步 语法分析(通篇扫描是否有语法错误),预编译(发生在函数执行的前一刻),解释执行(一行行执行). 1.2 预编译执行分五步 创建AO对象(Activat ...

  9. 【前端知识体系-JS相关】深入理解JavaScript原型(继承)和原型链

    1. Javascript继承 1.1 原型链继承 function Parent() { this.name = 'zhangsan'; this.children = ['A', 'B', 'C' ...

随机推荐

  1. idea使用lombok不生效的解决办法

    file-->setting-->plugins点击下方的 browse repositories. 搜索lombok plugin. 安装后,重启. file-->setting- ...

  2. 在dubbo的一端,看Netty处理数据包,揭网络传输原理

    如今,我们想要开发一个网络应用,那是相当地方便.不过就是引入一个框架,然后设置些参数,然后写写业务代码就搞定了. 写业务代码自然很重要,但是你知道: 你的数据是怎么来的吗?通过网络传输过来的呗. 你知 ...

  3. Java开发桌面程序学习(五)——文件选择器和目录选择器的使用

    选择器的使用 DirectoryChooser目录选择器官方文档 FileChooser文件选择器官方文档 文件选择器的使用 JavaFx中有个FileChoser,可以打开一个对话框来选择文件 Fi ...

  4. .NET MVC5简介(四)Filter和AuthorizeAttribute权限验证

    在webform中,验证的流程大致如下图: 在AOP中: 在Filter中: AuthorizeAttribute权限验证 登录后有权限控制,有的页面是需要用户登录才能访问的,需要在访问页面增加一个验 ...

  5. 学习Python前言

    先介绍下自己: 我是小芒果,在一家互联网公司上班 目前担任的是测试工程师职 自工作开始至今,已经3年之载 一路过来倒也轻松 期间学过几次python没一次能坚持下来 随着行业的饱和 测试技术的要求 以 ...

  6. zTree插件的应用

    需要用到的js和css文件 <link rel="stylesheet" href="__PUBLIC__/zTree/css/demo.css" typ ...

  7. .NET MVC5简介(一)

    就像是.NET Framework WebApi与.NET Core WebApi一样,.NET Framework MVC与.NET Core MVC的区别,也是框架的之间的区别.本系列先首先从.N ...

  8. CSS字体属性

    CSS字体属性 CSS Fonts(字体)属性拥有定义字体系列.大小.粗细和文字样式(如斜体) 字体系列 <style type="text/css"> div{ fo ...

  9. kali linux查看局域网下所有IP,并对指定IP实施局域网内攻击(断网,随时查看对方密码,上网痕迹等)

    首先我们打开我们熟悉的kali linux操作系统,利用指令: ifconfig 来确认本机的ip地址 确认了本机的ip地址之后,利用一下的指令查看局域网下所有ip: fping -g 本机IP地址/ ...

  10. ABP进阶教程2 - 组合查询

    点这里进入ABP进阶教程目录 更新数据传输对象 打开应用层(即JD.CRS.Application)的Course\Dto\GetAllCoursesInput.cs //Course数据传输对象(查 ...