web前端的春天 or 噩夢

来源:http://www.cnblogs.com/wjiaonianhua/archive/2016/10/11/5948070.html
-Advertisement-
Play Games

「 微信應用號可以做什麼」 簡單說,微信“小程式”可以為開發者提供基於微信的表單、導航、地圖、媒體和位置等開發組件,讓他們在微信的網頁里構建一個 HTML 5 應用。同時微信還開放了登錄和微信支付等介面,讓這個“小程式”可以和用戶的微信賬號打通。 簡單地說,目前微信“錢包”中的“大眾點評”、“京東商 ...


 

「 微信應用號可以做什麼」

 

簡單說,微信“小程式”可以為開發者提供基於微信的表單、導航、地圖、媒體和位置等開發組件,讓他們在微信的網頁里構建一個 HTML 5 應用。同時微信還開放了登錄和微信支付等介面,讓這個“小程式”可以和用戶的微信賬號打通。

 

簡單地說,目前微信“錢包”中的“大眾點評”、“京東商城”、“滴滴出行”等第三方服務就是應用號的一種雛形。

還有支付寶里的 “生活繳費”,“城市服務”等,都是這種範疇,只不過是直接集中在app裡面。

 

根據參與本次內測的“小道消息”創始人 Fenng 提供的信息,微信小程式向開發者開放了下列 API 介面:我們再來刷一張圖:

 

  1. 微信的目的似乎很簡單,就是希望把用戶使用App的動作都集中在微信上。
  2. 從開放介面看,這不就是 web app?混合app麽?
  3. 小程式就是一個依托微信,來開髮網頁APP的關係戶。
  4. html 、css3、js 又泥煤的更重要、更露臉了(笑 ?)

 

「 對 原生APP 開發人員的影響」

1. Android 、IOS 開發者飯碗會丟嗎?

 

呵呵,這個問題討論了多少年了?HTML5 API第一版標準出來的時候,都在展望設想,現在呢?手機主流不還是原生APP 的天下,雖說一定程度上網頁應用占了不少河山,原生app裡面也嵌入了大量web app 頁面程式。但歸根結底還是原生APP的範疇。一談到體驗、性能問題,就是硬體在發達,還是會想到原生app。

 

另外 App 天生的優勢,和硬體直接打通、自由奔放,功能、體驗更加友好。

微信是一個大平臺,在怎麼折騰還是小馬哥 說了算,哪天說給你介面封了就封了,說給你下了就下了,你只不過是去上邊嘗了嘗鮮。

所以,Android 、IOS 開發人員完全不必擔心會丟飯碗(短時間內),小程式也不會取代原生APP。

 

2.原生app人員應該學習HTML5、JavaScript嗎?

 

我以前文章早就說過,以後會很長時間甚至可能一直都是 “前端年”,絲毫不誇張。如果身為技術人員不擁抱變化,不get新技能,可能工種不會淘汰你,時間就會淘汰了你,

 

而且現在 Hybrid App 開發方式如此流行和輕便,各種框架+語言 都可以無壓力操作原生介面開發,比如 DeviceOne 、react native(火爆程度直逼安卓原生,甚至有超越趨勢),而且體驗也是極好的。

 

所以勸只會原生開發的小伙伴,有空學習 JavaScript吧!

「 對 web前端開發人員的影響」

身為 web前端開發里最帥的人,今天我從 專業前端開發者的角度,來分析下 【微信-小程式】會對我們有什麼樣的影響。

 

首先,它的出現不會影響到我的顏值(放心了);

 

然後,我們前面說了,這基本上就是 我們現在總是接觸到的 Hybrid App方式,你顫抖了嗎?HTML+CSS+JavaScript 快要一統河山了?單單從這方面來講的話,我們web 前端工程師 是應該高興還是高興,還是憂慮呢?

 

我們先簡單分析一下 開發移動混合APP 的方式,根據此網路圖分析:

 

 

  • 左邊一類(A)是繼續堅持使用HTML+CSS進行界面佈局,通過對頁面渲染進行優化和對標準JS進行原生擴展來實現跨平臺App開發。框架例如 MUI 、SUI、jquerymobile、ioinc。

 

  • 右邊一類(B)是放棄使用HTML+CSS的界面佈局,選擇一種第三方的中間語言(如JS,C#等)來映射成Android和iOS的系統調用,從而實現跨平臺。這種方式的界面佈局需要通過中間語言組合系統UI組件來完成,渲染性能比HTML+CSS的方式要好,但這樣也失去了HTML+CSS佈局的標準性和靈活便捷。但為了性能一切都忍了,至少目前這種方式已經占據了市場和開發狗的心。 如 Deviceone 、 React Native。

 

A類特點

簡單 快速,模版佈局現成,一般熟練 html5 css 的前端開發人員根據api都可以勝任、調用基本的原生介面 如相機、掃描、地理定位也夠用。但渲染太耗記憶體、性能堪憂。

 

B類特點

完全映射底層介面。通過中間件打通視圖 和底層藉口,利用中間語言 JS 來開發應用程式。渲染性能比HTML+CSS的方式強悍許多,但佈局和開發已經不是原生的 html+css+js了,這增加了難度和便捷性。

但此方式還是比原生app開發周期短很多,屬於web開發範疇,只不過開發方式包裝了一些技巧。性能直逼原生(原生小伙伴們,還不學前端?)

 

微信‘小程式’: web前端的春天 or 噩夢?

 

前面噴了那麼多,都是為我們這個問題來的。小程式的發佈對  web前端的春天 or 噩夢呢? 

 

  • 不言而喻,上邊經過我的分析,傻子也能看出來是滿篇的好處和福利了 也就是春天。html+css+js +各種前端框架經驗,你他喵的 小程式簡直是web前端開發人員的定製福利。

 

  • 值得擔憂的問題:福利好自然壓力大,以後前端開發又得多掌握一份技能 和 一套微信體系開發工具了,微信開發必須在微信提供的 寶寶箱 sdk里開發,而且也不是原生js語法 和react  、angular語法,它是 WXML 和 WXSS ,微信自體系。 

 

  • 進入全面 js時代,也不遠了 Any application that *can* be written in JavaScript, will eventually be written in JavaScript。

    “能用js寫的東西,就全部用js寫 ”,所以 以後入門門檻 會更高,後端 、原生app開發人員也都要掌握一些 JavaScript 技能。
    本身這些混合開發框架 就是用c++ /c 語言調用的硬體介面來映射給js 調用的,所以以後前端人員的競爭可能會變大,越來愈多的後端 或者原生APP開發人員會進入 JavaScript 的學習大軍,那麼本來普遍邏輯能力就強的他們,會不會侵蝕一部分前端開發的福利呢?

 

那麼以前企業項目 可能需要 一個wap、wap app、企業號,以後 會 + 一個 ‘應用號’開發。 工作量大了,企業成本也增高了,那麼涉及到我們個人, 工資會不會隨著業務量、工作量的增長而增長,這個才是關鍵問題。

 

總結:

擁有用戶的微信,無疑成為了移動互聯網最大入口。它的一舉一動,滋生無數機會。

所以我們是無奈的,接受就好,讓市場來考驗,讓用戶來決定。

APP開發人員不必跟風媒體恐慌,你只要保持自我,不斷學習,肯定是不會被淘汰的。

web開發人員高興之餘,也不要忘形,因為這意味著以後你會承擔更多的壓力和工作量,和更多其他行業進來的競爭者們,大家都準備好了嗎?

 

 

 

本文轉載自:http://mp.weixin.qq.com/s?__biz=MzI5ODM3MjcxNQ==&mid=2247483840&idx=1&sn=64e5721436ec85d4a6f633ca76f90e3c&chksm=eca79ac4dbd013d2712ee201f6b7f984d3ea6ad01a594d8b987c4d9674ec3f26d0253c55d886&scene=27#wechat_redirect


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • atitit.Servlet2.5 Servlet 3.0 新特性 jsp2.0 jsp2.1 jsp2.2新特性 1.1. Servlet和JSP規範版本對應關係:1 1.2. Servlet2.5一些變化的介紹: 1 1.3. Jsp2.02 1.4. Jsp2.12 1.5. Jsp2.2 ( ...
  • 在寫介面實現時,有時會有多個實現類。這篇文章介紹在調用時通過傳入字元串來指定具體的實現類。 一.介面與實現類: 在實現類中重寫了toString() 方法,可以自定義字元串,當調用時傳入指定的字元串就能獲取到相應的bean。 二.register書寫: 三.測試類: 運行結果,如圖: 備註: 在sp ...
  • 一 PYTHON 安裝 1. Python下載 (1) www.python.org官網 (2) 選擇可執行文件( 64位3.5.2Windows x86-64 executable installer或32位3.5.2 Windows x86 executable installer)、(64位2 ...
  • 一、簡述 1.對象關係映射文件,用於映射實體類和關係資料庫數據表之間的一個 xml 文件。 2.通過 Entity.hbm.xml 映射文件,Hibernate 可以理解持久化類和數據表之間的對應關係,也可以理解持久化類屬性與數據表列之間的對應關係。 3.映射主鍵、映射關聯關係。 二、各個節點 說明 ...
  • Atitit.java c#.net php項目中的view復用(jsp,aspx,php的復用) 1.1. Keyword1 1.2. 前言1 2. Java項目使用。Net的aspx頁面view1 2.1. Aspx的顯示源碼解決之道1 2.2. Get path n param2 2.3. 還 ...
  • 每天一個設計模式-2 外觀模式(Facade) 1.生活中的示例 客戶想要購買一臺電腦,一般有兩種方法: 1.自己DIY,客戶需要知道組成電腦的所有電子器件,並且需要熟悉那些配件,對客戶要求較高。 2.去電腦組裝公司,告訴他們你需要的電腦配置,再由電腦組裝公司的人來組裝電腦,這種方式比較簡單通用,現 ...
  • 開本系列,談談一些有趣的 CSS 題目,題目類型天馬行空,想到什麼說什麼,不僅為了拓寬一下解決問題的思路,更涉及一些容易忽視的 CSS 細節。 解題不考慮相容性,題目天馬行空,想到什麼說什麼,如果解題中有你感覺到生僻的 CSS 屬性,趕緊去補習一下吧。 不斷更新,不斷更新,不斷更新,重要的事情說三遍 ...
  • textInput綁定目的 textInput綁定主要用於或者元素。他提供了DOM和viewmodel的雙向更新。不同於value綁定,textinput綁定是實時更新的。 例如: Login name: Password: ViewModel: 源碼: Login name: Password: ... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...