前端開發的七宗罪

来源:http://www.cnblogs.com/shouce/archive/2016/01/07/5108620.html
-Advertisement-
Play Games

前端開發在最近幾年逐漸走紅,越來越多的開發者加入前端開發隊伍。但前端在大學中沒有課程體系,而且知識也在不斷更新著。大家對它的認識也各不相同。博主有過技術經理,項目經理,面試官,前端開發的經歷,參與過較多的前端開發項目,也結識了較多前端開發人員。基於這些因素我對前端有些較深刻的認識,和大家分享下。本文...


前端開發在最近幾年逐漸走紅,越來越多的開發者加入前端開發隊伍。但前端在大學中沒有課程體系,而且知識也在不斷更新著。大家對它的認識也各不相同。博主有過技術經理,項目經理,面試官,前端開發的經歷,參與過較多的前端開發項目,也結識了較多前端開發人員。基於這些因素我對前端有些較深刻的認識,和大家分享下。

本文取名七宗罪是有些噱頭之意,還請大家見諒,實則想為大家闡述前端開發的誤區。

 

罪一:前端只是JS

有這麼一部分朋友,只看犀牛書(《JavaScript權威指南》),每天研究JS這JS那的,認為這樣就算是前端開發了。

但我要說的是:前端不只是JS。

何謂前端開發?我認為,一切以展現為目標的工作,都是前端開發工作。在前端開發中,除了JS,還有很多需要去掌握的,比如瀏覽器原理,html5,css3等。之前在面試別人時,問他,怎麼做一個觸摸屏上的轉盤。他搖頭。我退了一步,和他說談談你的想法也可。他想了一下,還是不會。

做轉盤,是我經常面別人的一道題(我在後期會對這道題給大家解說),看似簡單,但代表了前端知識的綜合應用。你沒有觸摸屏開發經驗,不知道CSS3或canvas,不瞭解網頁優化,是做不出來的。前端是綜合技術的應用,只會JS是解決不了問題的。

 

罪二:我現在能HOLD住一切,不用學新東西了

我面過的人中,有60%的人沒有h5和CSS3的實際工作經驗,甚至只聽過一些名詞,沒有研究過。問他們原因,大部分回答之前的工作用不上,小部分回答沒時間。當問到一些動畫的實現時,有部分面試者還在用頻繁改DOM的CSS2屬性來實現。

這種狀況的原因可能和工作內容有關,目前國內的一些移動端網頁還是比較中規中矩的,產品經理對前端實現很少有非常規的要求。一些前端開發者的任務是把後端的數據給呈現出來即可,這些確實CSS2也能實現。但這些也不是不學不用新技術的理由,啃老本總有一天被淘汰。讓頁面的用戶體驗更好,是前端的責任。

 

罪三:前端不需要瞭解後端知識

也是,前端好好的弄前端唄,管後端幹嘛。

但行業在發展著,前端的功能越來越強大。離線資料庫能提供數據存儲和管理的功能,但不會寫SQL語句能玩得轉嗎?WebSocket能提供即時通信,但不瞭解socket和WebSocket的區別,能和後端開發(很多後端開發只會socket技術)一起搭建嗎?  加快頁面展示速度不只是要從前端分析,後端也要考慮到,使用keep alive、 緩存等後端技術能使頁面更快地打開。

 

罪四:設計師或產品經理太異想天開了,他們要的好難實現呀,乾脆回覆實現不了吧

不要排斥他們的非常規需求,他們的這些奇怪需求也許會成為企業的重要競爭力。(好吧,這一點切換到公司經營者的視角了。)用戶越來越註重表現效果了,不要再以簡單的列表頁和詳情頁來打發用戶了,他們可能會因為良好的用戶體驗而成為網站的忠實用戶。遇到非常規需求時,首先想下怎麼運用前端知識來實現,如果想不出來,就和同行討論下。總之,實現需求是開發者的責任,不要輕易說這個需求我們實現不了。

 

罪五:不考慮極端情況或性能,頁面出來就行

大部分前端呈現使用DOM,但DOM用得多了會有性能問題。現在很流行列表頁頁底上拉載入更多,但很少有前端關註載入的極端問題,如果一個頁面我下拉了很多次,載入了幾千個DOM,會發生什麼問題?答案是輕則頁面響應緩慢,重則瀏覽器閃退。

另外舉個例子:LocalStorage使用起來確實方便,很多企業的前端重度依賴它,甚至知名的前端開發框架也依賴它。但它有個缺點——有容量限制(2.6M-10M),我們得考慮極端情況,當LocalStorage空間快滿時,怎麼處理。或在架構上避免這種極端情況的發生。

 

罪六:頁面只是給用戶看的,用戶能正常使用就行

來看你頁面的,不只是用戶,還有機器人。

Web App一直在覬覦Native App的位置,有的Web App和Native App 根本看不出差別。Web App大紅大紫,各種前端MVC框架也風聲水起,但它們都有個問題,幾乎沒法做SEO,因為搜索引擎無視JS。流量是企業的立命之本,SEO做得好能引來大量的流量,所以前端還是得考慮SEO問題。(會在後面和大家討論Web App的SEO方案)

 

罪七:不使用/不推動 新技術


上帝給了你一雙翅膀,你卻把它給烤了。

問自己幾個問題,網頁用了CSS3動畫嗎?網頁支持多點觸摸操作嗎?距離感應器,動作感應器,你用了沒有?這裡並不是說為了用而用這些新技術。而是想表明,我們已經有新的技術了,不要把它們浪費了,是時候對以前的網頁和以前的操作方式進行變革了。使用這些特性,能讓用戶體驗更佳。一些產品經理或設計師對前端的認識還停留在html4時代,我們有必要和他們科普一下新知識。

轉載鏈接 http://www.cnblogs.com/arfeizhang/p/7mistakes.html


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

-Advertisement-
Play Games
更多相關文章
  • 有如下列表數據:0-PRODUCT1-10120001782-10126109763-10160000223-10160101784-10610000155-10620000025-10620000026-10620000027-10620000028-10135022309-10610101801...
  • 目 錄第十四章 序列號的設計... 214.1 設計原則... 214.2 設計思想... 314.3 代碼實現... 414.4 代碼混淆... 1814.5 代碼破解... 1814.6 小結... 18第十四章 序列號的設計 序列號作為軟體使用授權方式之一,被廣泛使用在應用軟體方面。主要考慮到...
  • 官方文檔:http://mp.weixin.qq.com/wiki/4/9ac2e7b1f1d22e9e57260f6553822520.html在介面許可權表將其修改成伺服器的功能變數名稱根據官方文檔,需要一個授權頁面鏈接,可以用封裝好的OAuthApi.GetAuthorizeUrl()方法實現1 ...
  • vi 的使用 基本上 vi 共分為三種模式,分別是『一般模式』、 『編輯模式』與『指令列命令模式』三種! 這三種模式的作用是: 一般模式: 以 vi 處理一個檔案的時後,一進入該檔案就是一般模式了。在這個模式中, 你可以使用『上下左右』按鍵來移動游標,您可以使用『刪除字元』或『刪除整行』來處理檔.....
  • 原文鏈接地址:http://www.cnblogs.com/lyhabc/p/3886402.html 一步一步走來已經寫到了第十六篇了~ 這一篇主要介紹MYSQL的優化,優化MYSQL資料庫是DBA和開發人員的必備技能 MYSQL優化一方面是找出系統瓶頸,提高MYSQL資料庫整體性能;另一方面需要...
  • 設置標題欄背景1> 準備背景圖片:background_pix.png註:用背景圖片比用顏色好處,可以讓背景看起來有凹凸感.2> drawable文件夾下放xml文件bitmap_repeat.xml 3> 定義樣式文件style.xml4> 在manifest.xml中引用主題android:th...
  • 筆者近2天在 Android Studio上玩了一下百度地圖,碰到了常見的"230錯誤 APP Scode校驗失敗",下麵我來介紹一下具體的解決辦法. 1.在andriodstudio上部署百度地圖的規範.把下載下來的SDK解壓,切換至Project視圖.複製以下3個文件到libs文件下. 2......
  • 2013年谷歌推出android studio後,單獨支持android開發,這是基於Java語言集成開發環境IntelliJ搭建的IDE。特別在android studio1.0穩定版出來後,谷歌將其作為官方的開發工具,也推薦開發者使用android studio。15年時候谷歌宣佈停止對ec.....
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...