前言

hello 小伙伴们,现在我已经正式入坑 uni-app 了。uni-app 已经发布好几个月了,期间也是踩坑无数,但是官方秉承着不抛弃不放弃的精神,积极解决开发者的各种简单的、复杂的问题,在此表示感谢。我想还有小伙伴正在持观望状态,还没想好要不要使用 uni-app,而且近些日子以来,许多跨端框架也纷纷出现在了大家的视线当中,让迷茫的我们更加不知道如何对比选择了。 uni-app 入坑指南,方便大家更好的了解 uni-app 本篇只讲述 uni-app,不与其他类似框架进行对比

一、什么是 uni-app

  1. uni-app 是一个使用 Vue.js 开发跨平台应用的前端框架,开发者编写一套代码,可编译到iOSAndroidH5、小程序等多个平台。详情点击 uni-app 官方文档
  2. uni-app在跨端数量、扩展能力、性能体验、周边生态、学习成本、开发成本等6大关键指标上拥有极强的竞争优势 。
  • 跨端数量更多
  • 平台能力不受限
  • 性能体验更优秀
  • 周边生态丰富
  • 学习成本低
  • 开发成本低

二、使用 uni-app 的前置条件

好多小伙伴可能要问了:哇,一套代码可以编译到那么多平台,那是不是我学习起来很麻烦啊,我只会vue啊,不会小程序,也不会原生开发,能不能学会uni-app呢。

这个问题问的就很棒,那么如果要学会uni-app需要会那些技能呢?答:你如果会vue,基本上就可以解决大多数问题了。多读几遍文档,你会发现开发起来很顺畅 。

但是为了更好的跨端开发,我们肯定是要统一规范的:

  • 页面组件我们要遵循Vue 单文件组件 (SFC) 规范
  • 组件标签靠近微信小程序规范
  • 接口能力(JS API)靠近微信小程序规范
  • 数据绑定及事件处理靠近 Vue.js 规范,同时补充了App及页面的生命周期
  • 为兼容多端运行,建议使用flex布局进行开发

三、开发工具

使用官方推出的 HBuilderX 编辑器

可视化的方式比较简单,HBuilderX 内置相关环境,开箱即用,无需配置node 。

四、使用Vue.js

几乎全支持 Vue官方文档:模板语法

当然,说的是几乎,那肯定有不支持的情况下啊, 下面给大家罗列一下不支持的情况 :

  • 不支持纯HTML
  • 不支持部分复杂的 JavaScript 渲染表达式
  • 不支持过滤器

五、小程序(微信、支付宝、百度、头条)

当然如果要开发小程序,不可避免的,我们肯定是要知道不同平台下的小程序规范的 。当然知道了这些规范之后,我们开发起来就比较简单了。uni-app 给我们把不同平台的小程序 API 几乎都封装了 ,只需要将前缀替换为 uni 即可 举例说明:

我们调用微信小程序的 request 请求

我们使用 uni-apprequest 请求

有没有发现什么不一样的?对了,除了前缀 wx替换为uni之外,其他的地方一摸一样,是不是这样开发起来就很一贼了呢 。

六、App(ios、安卓)

uni-app 不仅可以使用绝大多数的小程序相关的 API,同时也可以使用 5+API 很好的补足了小程序上一些还没有实现的功能,是不是很美好?而且开发方式还是跟上述一样,没有变化,是不是更美好了呢。

七、H5

h5 就不多说了,基本上跟常规 vue 开发没有什么区别, 唯一需要注意的是,有些 API 是不能在 h5 中使用,主要看文档,看文档,看文档 。

八、如何实现跨端

当然虽说是跨端,但是肯定是有情况是不支持的,比如遇到有些平台特有的 API 怎么办 ?

不用担心,这些问题 uni-app 都为你想到了 那就是使用条件编译

九、条件编译

(详细看文档)在 C 语言中,通过 #ifdef#ifndef 的方式,为 windowsmac 等不同 os 编译不同的代码 uni-app 参考这个思路,为 uni-app 提供了条件编译手段,在一个工程里优雅的完成了平台个性化实现 。

条件编译是利用注释实现的,在不同语法里注释写法不一样,js使用 // 注释css 使用 / 注释 /vue/nvue 模板里使用 **

举个例子:

是不是感觉很方便 ?这样就可以很巧妙的去区分不同的平台了,具体的请详细看文档,看文档,看文档 。

十、注意事项

  • H5 端,不能使用浏览器自带对象,比如 documentwindowlocalstoragecookie 等,更不能使用 jquery 等依赖这些浏览器对象的框架。因为各家小程序快应用都不支持这些对象。没有这些浏览器自带对象并不影响业务开发,uni 提供的 api 足够完成业务。
  • uni-apptag 同小程序的 tag,和 HTMLtag 不一样,比如 div 要改成 viewspan 要改成 texta 要改成 navigator

以上,所有内容(除了我自己说的话以外)都来自 uni-app官方文档,请注意多看文档,多看文档,多看文档。

api 微信内置浏览器js_多端开发框架uni-app入坑指南,一套代码适用微信、头条等小程序...相关推荐

  1. api 微信内置浏览器js_【微网站开发】之微信内置浏览器API使用

    最近在写微网站,发现了微信内置浏览器的很多不称心的地方: 1.安卓版的微信内浏览器底部总是出现一个刷新.前进.后退的底部栏,宽度很大,导致屏幕显示尺寸被压缩 2.分享当前网站至朋友圈时,分享的图片一般 ...

  2. api 微信内置浏览器js_微信开发-微信内置浏览器的Javascript API

    /**! * 微信内置浏览器的Javascript API,功能包括: * * 1.分享到微信朋友圈 * 2.分享给微信好友 * 3.分享到腾讯微博 * 4.隐藏/显示右上角的菜单入口 * 5.隐藏/ ...

  3. api 微信内置浏览器js_微信小程序和HTML的区别

    点击上方"程序员小鸿",马上关注,每天早上推送精彩文章,请置顶或星标 2017年1月9日0点,万众瞩目的微信第一批小程序正式上线,小程序出来已经有一段时间了,对于前端开发者来说,学 ...

  4. pc端微信内置浏览器不支持replaceAll方法

    问题背景:模块功能已经开发完成上线,做了移动端的适配后,需要微信内置浏览器打开,问题就在这里,谷歌打开是正常的,微信无法正常打开. (注:这是开发踩坑的记录,解决问题方案可直接跳到 2 - 3)查看即 ...

  5. chrome设置微信ua_Chrome谷歌浏览器在电脑上模拟微信内置浏览器的方法

    很多时候,我们在微信里打开链接,就是调用微信的内置浏览器,这个时候调试是很麻烦的,我们可以用谷歌浏览器模拟微信内置浏览器来做一些调试,就很方便了! 先了解安卓微信和Ios微信的UA(User agen ...

  6. 微信公众号 - 实现 H5 网页在微信内置浏览器中下载文件,可预览和下载 office 文件(doc / xls / ppt / pdf 等)适用于任何前端技术栈网站,兼容安卓和苹果系统!

    前言 网上的教程都是让你写页面 "引导" 右上角三个点里,让用户自己去浏览器打开,其实这样用户体验并不好. 本文实现了 最新微信公众号 H5 网页(微信内置浏览器中),预览下载 o ...

  7. 调试那些事儿之PC端微信内置浏览器

    一.前言 为什么要调试 PC 端微信内置浏览器呢?个人觉得原因可能如下: 1.用户在电脑上的微信内置浏览器打开网页,遇到了问题,开发就需要去排查问题 2.查看公众号网页的代码比较难查看,也不方便调试, ...

  8. ASP.NET MVC Display Mode 移动端视图 配置对微信内置浏览器的识别

    最近在捣鼓一个稍微有点low的商城网站,没有计划做app却要求有个wap版,而前端又没有做成响应式,时间WTF,直接利用了asp.net mvc的Display Mode Provider. 使用方式 ...

  9. pc端微信内置浏览器F12

    pc端微信内置浏览器F12 1.下载devtools_resources.pak https://files.cnblogs.com/files/wunaozai/devtools_resources ...

最新文章

  1. JSP 日期处理概述
  2. 蓝桥杯:基础练习 回文数
  3. 团队章程---促进团队更合作和更高效
  4. 几个预编译指令的用法
  5. 今天的你将感谢_您今天感谢系统管理员了吗?
  6. 二、Android应用的界面编程(六)ProgressBar及其子类[SeekBar、RatingBar]er
  7. Android模拟器环境下SD卡内容的管理
  8. js基础知识汇总06
  9. pythonqueue线程_python基于queue和threading实现多线程下载实例
  10. 打开服务器文件的asp代码,asp文件用什么打开
  11. eclipse:STS下载使用(STS(Spring Tool Suite)其实是个被包装过的eclipse)
  12. jdk7对list进行排序(按照list中entity的某个属性比如age)
  13. 如何使用Python给自己的头像添加国旗
  14. 【JVM笔记】Parallel Scavenge回收器:吞吐量优先
  15. 提供 Android 酷炫的开屏动画 (awesome-opening-animation)
  16. 【毕业设计_课程设计】基于python的微信公众平台机器人的设计与实现
  17. 区块链+大数据:万物互联时代的“CP组合”
  18. html显示json数据中某一条的数据,php - 给定一个具有json格式数据的API,我该如何在HTML表中显示数据? - 堆栈内存溢出...
  19. 基于pytest框架自动化测试脚本的编写 -入门到精通
  20. 六 Python 自学进阶,如果想要打牢基础,应该收藏它

热门文章

  1. Nacos配置中心-如何使用Nacos作为配置中心统一管理配置
  2. canal数据同步(开启binlog功能)
  3. 内置锁的能力不足以满足需求
  4. 数据库-优化-MYSQL数据库设计规范
  5. Servlet_3.0注解配置
  6. 静态方法-应用场景和定义方式
  7. 什么决定了电商双11大促的成败
  8. 函数作为返回值练习 作用域和作用域链及预解析 闭包 闭包小案例
  9. maven jersey mysql_jersey+maven构建restful服务
  10. 解决MySQL报错ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost:3306‘ (10061)