说说前端未来几年的发展方向

在知乎上看到这么一个问题,觉得很有意思,以下是原提问者的见解

过去五年前端的发展过程基本上是一个工程化的过程,框架和工程化工具层出不穷。

近两年其实发展已经比较迟滞了。

框架方面:基本就是三大框架鼎立的局面,三大框架都在相互借鉴吸收,而且方向各有侧重,未来短时间内我看格局不可能有什么大变化.

工程化工具:基本上是 webpack 一统江湖的趋势,虽然有 parcel 等来小打小闹,但是生态一旦形成,没有革命性的项目是无法取代 webpack 的,而且 webpack 也在进化.

个人认为前面五年是前端生产力提高的五年,工程化使得前端的生产力得到了极大提升,但是现在也基本上是在已有的格局中修修补补了

我谈谈我对前端未来几年的发展方向的看法。

看未来的发展方向,无非就是看现在的解决方案所存在的痛点。

1. 浏览器的性能问题

做 web 前端的同学都知道,和原生的 App 相比,性能一直一个致命的痛点,如果要追求性能,肯定得用原生 App。那么在性能上,未来几年可能是一个方向。

①前端代码编译为字节码

浏览器这几年在 Chrome 的带动下,性能飞速发展,但毕竟其核心原理没有变化,性能始终难以达到原生 App 的水平,这部分是很有可能出现大的变化的,一个可能的方向就是浏览器变成虚拟机,前端代码编译为字节码,通过这种方式来将性能提升一个等级,虽然还是难以达到原生App的水平,但已经能够满足绝大部分应用的性能需求,类似于Java对比C/C++一样。    --李运华

因为 js 是边解释边执行的,这肯定是要比编译型语言要慢,为了解决解释器的低效问题,大概在 2008 年的时候,提出了 JIT 的概念,它是使 JavaScript 运行更快的一种手段(JIT,内联缓存和隐藏类)之一,通过监视代码的运行状态,把 hot 代码(重复执行多次的代码)进行优化。通过这种方式,可以使 JavaScript 应用的性能提升很多倍。

但是时至今日,还是觉得不够快,所以各大浏览器厂商开始支持 WebAssembly。WebAssembly 是一种新的字节码格式,主流浏览器都已经支持 WebAssembly。

和 JS 需要解释执行不同的是,WebAssembly 字节码和底层机器码很相似可快速装载运行,因此性能相对于 JS 解释执行大大提升。

也就是说 WebAssembly 并不是一门编程语言,而是一份字节码标准,需要用高级编程语言编译出字节码放到 WebAssembly 虚拟机中才能运行.

他的优点就是:

  • 体积小:由于浏览器运行时只加载编译成的字节码,一样的逻辑比用字符串描述的 JS 文件体积要小很多;

  • 加载快:由于文件体积小,再加上无需解释执行,WebAssembly 能更快的加载并实例化,减少运行前的等待时间;

目前可以编译成为 WebAssembly 字节码有 :AssemblyScript(语法跟 TS 差不多,)、c\c++、Rust、Kotlin。

②统一的DOM树限制了单线程的渲染

理论上来说,一个页面某个时间变化的部分只是集中在一小块区域,没有必要将整个DOM树锁住。因此,一个可能的方向是分区渲染,即将页面划分为几个不同的区域,每个区域有独立的DOM树,独立渲染,那么性能会高很多,类似于 App 开发中的组件,组件类的运行不影响其它组件,如果需要依赖其它组件,通过组件间消息进行通信。

原生 App 不同平台重新开发的痛点

现在的 web 有两大优势,一个是浏览完毕直接走人,另外一个是跨平台,只要有浏览器,一切都好说。

所以现在有很多 hybrid 解决方案,某些页面通过 h5 的方式来展现。

想解决的无非就是少花点成本,写一份代码,可以在 ios 和 Android 上都可以用,进而也出来了想 RN、weex、NativeScript 这类 Learn Once, Write Anywhere(RN提出来的) ,但是他们最终都会翻译成原生代码。

但是用过这些的人都知道,还有很多坑,经常调侃 rn 的就是 write once ,debug anywhere。

Learn Once, Write Anywhere 的理念,背后就是跨端的思想,所以也诞生出来 electron、PWA 为代表的案例。

而且现在出现了 Taro 、mpvue 这些 h5 与小程序的统一的方案,所以未来在突破写一份代码在 h5 ,原生 app、小程序,甚至桌面应用都有可能。

另外提醒

  1. 我很早就跟星球里的朋友们说过,TS 一定会在火的,现在用 TS 的感觉,让我感觉跟 vim 很像,刚开始用的时候很难受,一旦习惯了就离不开了。未来项目会越来越复杂,用了 TS 项目的风险会可控很多。

  2. 多注重框架原理,现在对于前端工程化,个人认为差不多到了瓶颈期,很难有新的突破,注重原理才能很好的应对未来的发展。

  3. 眼界放宽、拓宽自己知识的广度。

欢迎大家把自己对未来几年前端的看法在留言区讨论,以上仅为个人观点。


公众号【前端桃园】

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Web前端未来发展方向可能会集中在以下几个方面:提高用户体验、增强网页性能、增强Web应用程序的安全性、支持新的Web技术和标准、实现可访问性、增强移动设备兼容性和进一步扩展Web应用程序的功能。同时,前端开发将更加注重跨平台的兼容性和可维护性,适应不同设备类型的屏幕大小和分辨率,以及更加灵活高效的开发工具和框架。 ### 回答2: Web前端发展方向主要包括以下几个方面。 首先,响应式设计将成为Web前端的主流。随着设备类型的增多,人们更加注重在不同屏幕尺寸和设备上都能够提供良好的用户体验。响应式设计可以根据用户的设备尺寸和屏幕分辨率自动调整网页的布局和内容,使其在各种设备上都能够展现出最佳效果。 其次,移动端发展给Web前端带来了新的挑战和机遇。移动设备的普及推动了移动应用的发展,所以Web前端需要关注移动性能、移动用户体验以及移动端的适配等问题。同时,移动端还催生了PWA(Progressive Web App)的概念,即渐进式Web应用程序,它能够在离线状态下运行,具备更接近原生应用的用户体验。 另外,Web前端将更多地融合到人工智能和大数据等新技术中。以网络搜索为例,通过新技术的应用,搜索引擎能够提供更加智能化的搜索结果和个性化的推荐,这需要Web前端开发者具备对人工智能和大数据等技术的理解和应用能力。 此外,Web前端的开发工具和框架也在不断更新和发展。比如,React、Vue和Angular等前端框架的出现使得前端开发更加高效和灵活,同时还有Webpack、Babel等工具可以帮助前端开发者更好地进行代码打包和转换等工作。 综上所述,Web前端未来发展方向是响应式设计、移动端发展、结合人工智能和大数据等新技术以及不断进化的开发工具和框架。随着互联网的不断发展,Web前端发展也将持续跟进和适应新的技术和需求。 ### 回答3: web前端是一个发展迅速的行业,未来有许多新的发展方向。首先,响应式设计将是一个重要的趋势。随着越来越多的用户使用移动设备访问互联网,开发响应式网站能够在不同的设备上提供一致的用户体验将变得越来越重要。 其次,前端框架和库的发展将继续。目前已经存在许多成熟的前端框架和库,如Angular、React和Vue.js等,它们能够提高开发效率和代码质量。未来,这些框架和库将继续优化和创新,提供更好的工具和功能,帮助开发者更好地构建复杂的应用程序。 另外,人工智能和机器学习的应用也将在前端开发中起到重要作用。随着人工智能技术的发展前端开发可以利用这些技术来优化用户体验,例如自动化测试、智能推荐和数据分析等。 此外,前端开发也将更加注重用户体验和可访问性。随着用户对网站和应用程序的期望提高,开发者需要关注网站的性能、易用性和可访问性,以确保用户获得良好的体验和无障碍的访问。 总的来,web前端未来发展方向包括响应式设计、前端框架和库的优化、人工智能和机器学习的应用,以及更注重用户体验和可访问性。随着技术的不断演进和用户需求的变化,前端开发将继续在互联网行业中发挥重要作用,并持续发展

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值