`
bugtags
  • 浏览: 29548 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

为什么 JavaScript 会在移动端中胜出?

阅读更多

 

JavaScript并不是世界上最优美的编程语言。正因如此,一个世界级的专家写了一本关于这个语言的“精粹 ”的书。这本书的名字是“深度挖掘javascript的亮点”,因为优秀的东西被埋的相当深。即便如此,它还是迅速地称为世界上最受欢迎的语言之一。这种受欢迎是应得的,因为尽管这种语言存有缺陷,但是javascript提供给开发者其它语言不能给予的重要的优势。有一些优势是在浏览器的开发商同意了Javascript(好吧,技术上的ECMAScript)作为web语言的标准后产生的。其它的是固有的web应用编程模型以及更没有通过什么增强改进。然而,尽管原生态的应用程序统治了web应用在移动设备上的地位,但是JavaScript的优势正在逐步转向移动设备。最终它会主宰吗?



此处应有图片

流行然而并不优先

  • 最近的TIOBE社区列表将JavaScript列为在所有编程语言中的第六位并且还在持续上升。TIOBE方法的排名倾向于支持老旧的,更加成熟的语言,而不太擅长去追随潮流。相比之下,Redmonk排名方法将JavaScript放在第一的位置上。Redmonk方法某种程度上会偏向于有着强大开源社区的语言,但是同时在实质上会反映现在的趋势和兴趣点。我们自己的开发者经济概览已经表明HTML5/Javascript的联合已经是移动端开发者所采用的第二流行的语言,几乎55%的人使用。仅仅以微小的优势输给57%的人使用java。然而,尽管我们发现HTML5和Javascript的组合在优先选择的人群上为(19%),在这个方阵上远远落后于Java(29%)。这看起来会在未来几年显著提高。[你怎么认为呢?我们已经有了一个新的调查,所以看看这个调查然后让我们知道你的看法]

JavaScript在浏览器上飞向自由

  • 这并不是一个标准的“网赢”的说法。我并不认为浏览器或者是基于网络视图的应用程序最后会统治移动设备。即使使用而且增长但不会是常态。如果将来真的开放web标准来统治移动设备那么他们需要从文档对象模型(DOM)开始。DOM不是构建应用程序,而是文档的基础。当然你可以最初围绕一个平台设计一个用于文档的应用程序,但是你会举步维艰。看一眼现在的框架,允许你为移动浏览器或网络视图设计的相当高性能的应用程序:React.js 、 Famo.us 和lonic。这三者的共同点就是尽可能少用DOM。

  • 是的,有太多的 WebGL(或者说 HTML5 Canvas 必备),但是这些都是低级别的 APIs。你所需的是大的、可能是多字节的、好的框架为开发大多数应用来创建一个优秀的平台。这不太适合 web 应用编程模型,其中最新的程序代码是放在一个远程的服务器上,尤其不适用在一个移动的环境中。能在一个大的好的存储在本地的WebGL上创建一个混合型的应用是真的,而且只是从远程的服务器上获取程序特定的代码。但是为什么要使用浏览器呢?为什么不只是 javaScript 能优于其他的在硬件图形加速器(提示:Qt 提供不错的产品)的跨平台框架。一个高级别的 API 在语言之间的桥接上是不会有那么多的开销的。或许在涉及访问特定功能的时候也是欠缺限制。

  • 现在有几个符合这一描述的非常有趣的新选择。 React Native 和 NativeScript.。它们以不同的方式运行,但是二者都是用 JavaScript 来构建一个原生态 UI 的应用程序。Appcelerator 的 TiNext 可能也是很有意思的,即使它们多年来被多次谈论却不曾公开一个版本,因此让我们耐心等待并一睹它的风采。

JavaScript异常

  • 苹果已经恢复了JavaScript 在移动端的优势。阻止了大多数开发人员在移动端采用一个敏捷、web 样式持续交付模型的冠一个关键事情就是 Apple 在代码下载上的禁令。如果没有这种迭代模式的显著放缓,对比测试会更加困难。这实际上就意味着开发者,尤其是初学者,会学的慢些。直到最近,唯一获取更快的迭代的方式就是首先从 Android 开始,开发一个混合的应用程序,因为 Apple 使得JavaScript 称为在 webview 代码下载规则中的一个异常。在第一种情况下,它意味着大多数早期的采纳者正在远离这个平台。不幸的是第二种情况下 UX 的取舍实在是太大了,大多数开发者因为用户用程序故障或者切换到本地去走那条路线。但是在 ios7 中为运行 JavaScript 增加了 JavaScriptCore 接口,而且最新的 ios 开发者程序许可证条款中,他们修改了代码下载异常的规则包括 JavaScriptCore。

  • 这从安全的角度上讲是有道理的。Apple 能审计和更新他们的运行时间,然而如果他们允许地第三方运行时下载代码,他们就没有有效地监控安全问题。因为 JavaScript 是 Apple 的唯一脚本选项并且他们不允许下载代码到本地,JavaScript 在恢复特权地位–作为那些想快速迭代的唯一选择。JavaScript 的可用性引发了一些努力,像 React 和 NativeScript 和 Apple 对代码下载政策的放宽把握已经完美地对外公布。

开放会赢吗?

  • Web 提倡者有时候表明基于 web 的开放标准最终会胜利,因为开放一直都会赢。然而,Linux 就是一个明显的例子,这是一个开放的迅速发展的却没有委员会统一标准的生态系统。React,Facebook 似乎成了开源项目中快速构建的一个开发者生态系统。已经有了一个围绕 React.js 快速成长的委员会,这明显给他们带来了领先的机会。但是在 Telerik 的 NativeScript 团队正与 Google 共同工作,因此Angualr2.0 需要被无缝集成。Google 打算支持非 DOM 的环境,不管 web 标准是否朝向它。微软和谷歌可能需要一段很长的时间来支持他们在未来浏览器将实施的的标准。但是他们在共同朝着 TypeScript 努力,使构建一个负复杂一点的带有 JavaScript (证明是编译器在发现类型不匹配上比人聪明)应用程序更加简单。

  • Apple 已经为他们的新 Swift 语言建立了许多相当令人印象深刻的工具,尤其是互动场景(interactive playground)。然而,Facebook 在 React Native 上依据即刻反馈和高频即时编码可能已经有了更好的编码体验。苹果将会继续迭代他们的工具,开发者社区现在已经增加了这些新的 JavaScript 环境工具。Android 可能技术上是开源的,但是它在社区建设上却不是开放的。谷歌正在独自增强 Android 的平台和工具。大概真的是开放的开发者社区才会胜利,而真正基于社区的开源能够比基于开源标准的开放迭代更快。为此,“本地的 UX 使用 JavaScript 去建立”环境并取得成功,这样的平台肯定不会失败。应用还是会依据平台的外观和感觉,并采用新的特定平台的 API 去建立。

  • 这个时候,看起来好像非常开放的JavaScript开发者社区将要赢得胜利了,因为他们制作的APP具有本地平台的的外观,感觉和性能,除了需要有Web开发的经验。封闭平台以往一直取胜是因为那时候的APP需要为他们封闭的生态系统定制。目前,开放的web标准还是输的。如果手机浏览器厂商能同意新标准,让他们制作的应用能具有本地应用那样的体验,那么他们就一定会取得胜利。

你是用什么来制作的?

  • 你认为JavaScript将会掌控移动开发的未来吗?还是Java,Objective-C和Swift继续它们的领导地位? 那物联网,它的后端会通过Node.js吗?通过调查,让我们知道你用什么来建立你的APP吧。

原文链接

 

分享到:
评论

相关推荐

    h5PickerView纯原生Javascript实现的移动端多级选择器插件

    本文将深入探讨一款名为h5-PickerView的纯原生JavaScript实现的移动端多级选择器插件,它以其小巧的体积和高效的性能,为开发者提供了便捷的解决方案。 一、h5-PickerView简介 h5-PickerView是一款基于JavaScript...

    一个基于原生JavaScript开发的移动端省市县三级联动插件

    这种交互方式被称为“联动”,在移动端尤其常见,因为它可以节省屏幕空间并提供良好的用户体验。 原生JavaScript是这种插件的核心,它不需要依赖任何外部库如jQuery或Vue,使得代码更轻量级,加载更快,且对性能...

    jQuery手机移动端点击弹出时间选择代码

    在标题为“jQuery手机移动端点击弹出时间选择代码”的项目中,我们关注的是一个基于jQuery的解决方案,它允许用户在手机或平板电脑上方便地选择时间。这个功能对于日程安排、预订系统或者任何需要输入时间的应用都...

    Leaflet移动端友好的交互式地图JavaScript库

    Leaflet是一款轻量级的开源JavaScript库,专为移动端设计,提供了强大的交互式地图功能。在Web开发中,地图的展示和交互性往往是一个重要的需求,尤其是在地理信息系统(GIS)应用中。Leaflet的出现,使得开发者能够...

    【JavaScript源代码】javascript实现移动端轮播图.docx

    10. **触屏滑动支持**:在移动端,添加对触摸事件的支持,如`touchstart`、`touchmove`和`touchend`,以实现手指滑动切换图片。 以上就是使用JavaScript实现移动端轮播图的主要技术点。实际开发中,还可能涉及到...

    JS移动端点击弹出遮罩层

    下面将详细介绍如何使用JavaScript来实现这一功能,以及在移动端适配方面需要注意的关键点。 首先,我们来构建HTML结构。在这个例子中,我们需要一个按钮触发遮罩层的显示,并且需要一个遮罩层元素本身: ```html ...

    vue实现移动端拖动排序

    这一技术在移动端的交互设计中非常常见,如在列表编辑、图片轮播、九宫格布局等场景中。Vue.js是一个构建用户界面的渐进式JavaScript框架,它提供了一套响应式数据绑定和组件化的开发模式,非常适合用来开发具有丰富...

    移动端Dialog弹出对话框插件同时支持jQuery和Zepto

    在移动端Web应用开发中,用户交互的体验至关重要,而Dialog弹出对话框是常见的交互元素之一。`dialog.js`插件就是为了满足这种需求而设计的,它专为移动端优化,同时兼容了两种流行的轻量级JavaScript库:jQuery和...

    移动端在线聊天HTML效果

    在移动端在线聊天应用开发中,HTML、CSS和JavaScript是构建用户界面的核心技术。这个压缩包文件"移动端在线聊天HTML效果"包含了一个纯手工打造的移动端聊天界面的示例,旨在展示如何利用这些技术来实现一个功能完备...

    jQuery+HTML5手机移动端遮罩弹出菜单代码

    它利用了强大的JavaScript库jQuery和现代Web技术HTML5,创建了一个在手机屏幕上能够无缝展示的弹出菜单,为用户提供了便捷的导航体验。 首先,让我们了解一下jQuery。jQuery是一个轻量级、高性能的JavaScript库,...

    h5移动端部门树展示

    在移动端,H5能够提供跨平台的解决方案,无需考虑不同操作系统之间的兼容性问题。 2. **响应式设计**: 为了适应不同设备的屏幕尺寸,我们需要采用响应式设计。通过CSS3的媒体查询(Media Queries)和Flexbox或...

    jQuery手机移动端点击弹出数字键盘输入代码.zip

    jQuery作为一款广泛使用的JavaScript库,提供了丰富的功能来优化网页交互,其中包括在手机移动端实现点击弹出数字键盘输入的功能。本篇文章将深入探讨这一话题,帮助开发者理解并掌握相关技术。 首先,我们需要了解...

    svg在移动端的应用-手势图片拖动,手势放大缩小

    SVG(Scalable Vector Graphics)是一种基于XML的矢量图像格式,它在Web开发中扮演着重要的角色,特别是在移动端应用中。与传统的位图(如JPEG或PNG)不同,SVG图像无论放大多少倍都能保持清晰,这使得它非常适合...

    vuecomponents移动端UI组件库

    在JavaScript开发中,尤其是在移动端,UI组件库扮演着至关重要的角色。它们不仅简化了开发流程,还确保了应用的跨平台兼容性和一致性。Vue.js,作为一款轻量级的前端框架,以其易学易用和高效的性能深受开发者喜爱。...

    移动端下拉翻页效果

    在移动端开发中,下拉翻页效果是一种常见的用户体验设计,它允许用户通过在屏幕上向下滚动来加载更多内容,通常用于无限滚动列表或者分页浏览。这种效果在新闻、社交媒体、电商应用等场景中广泛使用,因为可以有效地...

    移动端rem开发自适应js写法

    在移动端Web开发中,REM(Root Em Unit)是一种常用的单位,它允许我们基于根元素(通常是html元素)的字体大小来设置元素的尺寸,从而实现页面的响应式设计。使用JavaScript进行REM布局的动态调整,可以更好地适应...

    hui移动端前端框架

    在开发流程中,开发者可以利用HUI提供的脚手架工具快速初始化项目,然后根据需求添加或定制组件,通过CSS样式和JavaScript交互实现具体功能。同时,HUI的文档详尽且更新及时,对于初学者和有经验的开发者来说都是...

    JavaScript写移动端答题网页程序的题目json数据

    JavaScript写移动端答题网页程序的题目json数据

    js移动端树型列表

    在移动端,我们还需要考虑触摸事件和响应式设计。可以使用`touchstart`代替`click`事件,以确保在触屏设备上的良好交互体验。同时,通过媒体查询(`media queries`)调整样式,确保在不同屏幕尺寸下的布局效果。 此外...

    移动端响应式框架

    在移动端Web App的开发中,一个常见的响应式框架是Bootstrap。Bootstrap提供了一套预定义的CSS样式和JavaScript组件,如栅格系统、导航栏、按钮、表单、模态框等,这些都可以快速搭建出响应式的页面布局。Bootstrap...

Global site tag (gtag.js) - Google Analytics