
区别一、运行环境的不同
传统的网页H5的页面运行环境是浏览器,包括webview,而微信H5网页的运行环境并非完整的浏览器。
区别二、是开发成本的不同
一个网页H5web开发需求时,开发工具(vscode、sublimtext、Atom等),大到前端框架(Angular、react、vue、backbone等)、模块管理工具(Webpack 、Browserify 等)、任务管理工具(Grunt、Gulp等),小到UI库选择、接口调用工具(ajax、Fetch Api等)、浏览器兼容性等都要考略。
一个微信H5的开发需求时,微信团队提供了开发者工具,并且规范了开发标准,前端常见的HTML、CSS变成了微信自定义的WXML、WXSS,WXML中尽管全部是自定义标签,但官方文档中都有明确的使用介绍,相信上手应该是非常容易的。
区别三、是获取系统级权限的不同
微信H5相对于网页HTML5 web应用能获得更多的系统权限,比如网络通信状态、数据缓存能力等,这些系统级权限都可以和微信小程序无缝衔接,而这一点恰巧是HTML5 web应用经常被诟病的地方,这也是HTML5的大多应用场景被定位在业务逻辑简单、功能单一的原因。
区别四、是应用在生产环境的运行流畅度。
无论对于用户还是开发者来说,都是最直观的感受。当HTML5应用面对复杂的业务逻辑或者丰富的页面交互时,需要不断的对项目优化来提升用户体验。但是由于微信H5运行环境独立,但配合微信的解析器最终渲染出来的是原生组件的效果,自然体验上将会更进一步。
首选从产品的角度来讲
公众号内嵌H5开发的时候,微信底部会提供相应菜单作为功能的引导入口,最终的页面还是会把用户引导到H5页面,而在用户体验方便跟原生APP开发还是有相当大的差距。而微信小程序它提供了丰富的框架组件和API接口供开发者调用,具体包含:界面、视图、内容、按钮、导航、多媒体、位置、数据、网络、重力感应等。在这些组件和接口的帮助下,运行在微信上的小程序基本保持和Native APP一样的流畅度,极大的提高了用户的体验。
然后从开发的角度来讲
不论是APP、H5,它们的Server端都一样,所以这里不讨论。
之前的开发就是我们讲的传统的前端:html、js、css,加上微信用js提供的一些原生能力,最终的展现形式也是用手机内置浏览器(WebView)打开我们的页面,但是归根结底都是H5,这种方式我们应该熟悉的不能再熟悉了。小程序我们可以简单粗暴的理解为RN(React Native),用大白话来讲就是用H5写的程序,最后以Native App的方式来运行,他们的原理都是用JS调用底层Native组件。
现在但凡只要是有微信的人都对微信的小程序不陌生,而且微信小程序的数量早已达到数百万个,其实现在不但只有微信小程序,包括支付宝、百度甚至头条等等都开始了自己小程序之路。这样企业在 开发移动端 的时候就会面临一个问题是选择 开发小程序 还是H5好呢?所以 济南文汇传媒 的我就来总结一下小程序和H5的区别,来看一下两者有何不同?让您能更好地选择。
首先先来看一下二者在概念上的区别:
小程序:就是依赖于微信或其他APP上的一个应用形式,无法脱离其所在的APP。
H5:可以单纯地认为是网页,用在移动端或者PC端的网页开发技术。
再来看一下二者其他方面的区别:
一、开发的成本不同
小程序因为是在特定的环境中去开发,所以它的组件、UI都是确定好了的,也不用去考虑兼容问题,修改的次数就会减少,这样成本会低一些。
H5在开发时会有开发工具的选择、框架的选择、UI的选择等问题,还要兼顾到浏览器是否兼容的问题,可能会面临多次修改,这样会增加成本。
二、加载速度的不同
在速度上,小程序依然基于APP端去实现,这样在使用时就感到很流畅。
因为H5是网页的原因,所以如果有很多功能或者需要加载的话,可能会比较慢一些。
三、运行环境的不同
前面我们说到了小程序只能在特定的APP端内运行,所以没有APP端也就无法使用小程序。
H5是网页,只要有浏览器就可以使用,手机自身的浏览器就可以使用。
四、用户体验的不同
H5网页是在浏览器内使用,如果网速不佳或者网页上需要加载的东西过多就会出现“很卡”的现象。
小程序在首次使用的时候是需要查找的,可能不会很精准,但是一旦使用之后页面加载等就会很流畅了。
好了,上面的这些内容就是关于小程序与H5之前的区别,其实两者各有优缺点,还是根本自身的成本问题或者需求进行选择吧。
以上就是关于网页h5页面跟微信h5页面有什么不同全部的内容,包括:网页h5页面跟微信h5页面有什么不同、微信小程序开发和公众号内嵌H5开发有什么区别、移动端开发选择小程序和选择H5有什么不同两者有何区别等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)