前端开发

前端开发是创建Web页面或app等前端界面呈现给用户的过程,通过HTML,CSS及JavaScript以及衍生出来的各种技术、框架、解决方案,来实现互联网产品的用户界面交互  。它从网页制作演变而来,名称上有很明显的时代特征。在互联网的演化进程中,网页制作是Web1.0时代的产物,早期网站主要内容都是静态,以图片和文字为主,用户使用网站的行为也以浏览为主。随着互联网技术的发展和HTML5、CSS3的应用,现代网页更加美观,交互效果显著,功能更加强大。

移动互联网带来了大量高性能的移动终端设备以及快速的无线网络,HTML5,node.jS的广泛应用,各类框架类库层出不穷。

发展历程

前端技术的发展是互联网自身发展变化的一个缩影。

前端技术指通过浏览器到用户端计算机的统称,存贮于服务器端的统称为后端技术。

前端开发主要职能就是把网站的界面更好地呈现给用户。

以前会Photoshop和Dreamweaver就可以制作网页,随着网站开发难度加大、开发方式多样,网页制作更接近传统的网站后台开发,网页制作更多被称为Web前端开发。前端技术包括4个部分:前端美工、浏览器兼容、CSS、HTML“传统”技术与Adobe AIR、Google Gears,以及概念性较强的交互式设计,艺术性较强的视觉设计等。

在Web1.0时代,由于网速和终端能力的限制,大部分网站只能呈现简单的图文信息,并不能满足用户在界面上的需求,对界面技术的要求也不高。随着硬件的完善、高性能浏览器的出现和宽带的普及,技术可以在用户体验方面实现更多种可能,前端技术领域迸发出旺盛的生命力。

2005年以后,互联网进入Web2.0时代,各种类似桌面软件的Web应用大量涌现,前端由此发生了翻天覆地的变化。网页不再只是承载单一的文字和图片,各种富媒体让网页的内容更加生动,网页上软件化的交互形式为用户提供了更好的使用体验,这些都是基于前端技术实现的。

随着手机成为人们生活中不可或缺的一部分,成为人们身体的延伸,人们迎来了体验为王的时代。移动端的前端技术开发前景宽阔。此外,前端技术还能应用于智能电视、智能手表甚至人工智能领域。

核心技术

HTML语言

掌握HTML是网页的核心,是一种制作万维网页面的标准语言,是万维网浏览器使用的一种语言,它消除了不同计算机之间信息交流的障碍。因此,它是网络上应用最为广泛的语言,也是构成网页文档的主要语言,学好HTML是成为Web开发人员的基本条件。

HTML是一种标记语言,能够实现Web页面并在浏览器中显示。HTML5作为HTML的最新版本,引入了多项新技术,大大增强了对于应用的支持能力,使得Web技术不再局限于呈现网页内容。

随着CSS、JavaScript、Flash等技术的发展,Web对于应用的处理能力逐渐增强,用户浏览网页的体验已经有了较大的改善。不过HTML5中的几项新技术实现了质的突破,使得Web技术首次被认为能够接近于本地原生应用技术,开发Web应用真正成为开发者的一个选择。

HTML5可以使开发者的工作大大简化,理论上单次开发就可以在不同平台借助浏览器运行,降低开发的成本,这也是产业界普遍认为HTML5技术的主要优点之一。AppMobi、摩托罗拉、Sencha、Appcelerator等公司均已推出了较为成熟的开发工具,支持HTML5应用的发展。

CSS

学好CSS是网页外观的重要一点,CSS可以帮助把网页外观做得更加美观。

JavaScript

学习JavaScript的基本语法,以及如何使用JavaScript编程将会提高开发人员的个人技能。

操作系统

了解Unix和Linux的基本知识,对于开发人员有益无害。

网络服务器

了解Web服务器,包括对Apache的基本配置,htaccess配置技巧的掌握等。

优化

尽量减少HTTP请求 (Make Fewer HTTP Requests)

减少DNS 查找 (Reduce DNS Lookups)

避免重定向 (Avoid Redirects)

使得 Ajax 可缓存 (Make Ajax Cacheable)

延迟载入组件 (Post-load Components)

预载入组件 (Preload Components)

减少DOM元素数量 (Reduce the Number of DOM Elements)

切分组件到多个域 (Split Components Across Domains)

最小化iframe的数量 (Minimize the Number of iframes)

杜绝 http404错误 (No 404s)

以上10条涵盖了Web前端开发中遇到的各种页面处理技术,让前端开发人员能够准确和快速地把握整个网页的架构,从而达到减少开发成本和页面美化目的。

前端框架

学好Web框架

熟悉掌握HTML、服务器端脚本语言、CSS和JavaScript之后,学习Web框架可以加快Web开发速度,节约时间。PHP程序员可选的框架包括CakePHP、CodeIgniter、Zend等,Python程序员喜欢使用Django和 webpy,Ruby程序员常用RoR。

随着Web 越来越规范和标准的统一,Web组件化技术不断革新,移动端开发不断升华,以下是一些常见开源前端框架:

Bootstrap

主流框架之一,Bootstrap 是基于 HTML、CSS、JavaScript的,它简洁灵活,使得 Web 开发更加快捷。

html5-boilerplate

该框架可以快速构建健壮,且适应力强的web app或网站。

Meteor

Meteor是新一代的开发即时web应用的开源框架,它能在较短时间内完成开发。

Semantic UI

基于自然语言有效原则的UI组件框架

Foundation

优秀的响应式前端框架

Materialize

基于材料设计的现代化响应式前端框架。可提供默认的样式,自定义组件。此外,Materialize还改进动画和过渡,为开发人员提供流畅的体验。

Pure

几乎可以在每一个web项目中使用的一组小的和响应式的CSS模块。

Vue

Vue.js 是用于构建交互式的 Web 界面的库。它提供了 MVVM 数据绑定和一个可组合的组件系统,具有简单、灵活的 API。

Skeleton

Skeleton 是一个小的 JS 和 CSS 文件的集合,可快速开发漂亮的网站,适合各种屏幕设备包括手机。Skeleton 基于 960 grid 开发。它是一个 UI 框架。

Amaze UI

国内首个开源HTML5跨屏前端框架产品系列,中文排版支持更优、本土化组件丰富。该产品系列中有专门针对移动端的HTML5混合应用开发框架Amaze UI Touch以及针对跨屏HTML5网页开发的Amaze UI Web。其中,Amaze UI Touch可以帮助开发者通过丰富的组件,快速构建出与原生APP相媲美的专属移动端的HTML5应用。

UIkit

一个轻量级的和模块化的前端框架,用于快速开发和功能强大的web接口。

Yui

Yahoo! UI Library (YUI) 是一个开放源代码的 JavaScript 函数库,为了能建立一个高互动的网页,它采用了AJAX, DHTML 和 DOM 等程式码技术。它也包含了许多 CSS 资源。使用授权为 BSD许可证。

kissy

一款跨终端、模块化、高性能、使用简单的 JavaScript 框架。

MUI

最接近原生App体验的前端框架的框架。

Arale

一个开放、简单、易用的前端基础类库。

JX

JX 是模块化的非侵入式Web前端框架,特别适合构建和组织大规模、工业级的Web App。

GMU

GMU是基于zepto的mobile UI组件库,提供webapp、pad端简单易用的UI组件! Web App。

ZUI

开源HTML5前端框架

Clouda Touch.js

Touch.js是移动设备上的手势识别与事件库,也是在百度内部广泛使用的开发。

职业机会

常见前端开发工程师职位职责要求:

(1)使用Div+css并结合Javascript负责产品的前端开发和页面制作。

(2)熟悉W3C标准和各主流浏览器在前端开发中的差异,能熟练运用DIV+CSS,提供针对不同浏览器的前端页面解决方案   。移动HTML5的性能和其他优化,为用户呈现最好的界面交互体验和最好的性能。

(3)负责相关产品的需求以及前端程序的实现,提供合理的前端架构   。改进和优化开发工具、开发流程、和开发框架 [

(4)与产品、后台开发人员保持良好沟通,能快速理解、消化各方需求,并落实为具体的开发工作   ;能独立完成功能页面的设计与代码编写,配合产品团队完成功能页面的需求调研和分析。

(5)了解服务器端的相关工作,在交互体验、产品设计等方面有自己的见解。

盲目的自学摸索只会浪费时间,好的学习方法建立起有效率的学习方式,以及应该如何写简历,如何就业,
有这方面不懂的问题随时问我,给大家进行解答。自己也整理了一份学习资料。这是我的前端开发qun,【六零三】【九八五】【九九三】,直接群里下载,
对于学习web前端有任何问题(学习方法,学习效率,如何就业)都可以问我,最后可以点一波关注哟

资深前端开发工程师

相比较“前端开发工程师”而言,更加资深,工作职责更大。一般而言,资深前端开发工程师需要使用JavaScript或者ActionScript来编写和封装具有良好性能的前端交互组件,熟练使用CSS+XHTML完美输出视觉界面。同时还要对Web项目的前端实现方案 提供专业指导和监督并在日常工作之中对新人及相关开发人员进行前端技能的培训和指导。另外,还要跟踪研究前端技术,设计并实施全网前端优化。HTML5、node.js(JavaScript编程的后台语言)兴起,要求资深前端熟悉后端,并且要在商业模式、代码架构思想等维度去整体考虑前端的全局布局。

前端架构师

前端架构师更偏管理,但职责要求不仅限于管理。前端架构师需要带领组员实现全网的前端框架和优化,创建前端的相应标准和规范,完善并推广和应用自己的标准和框架。同时,还要站在全局的角色为整个网站的信息架构和技术选型提供专业意见和方案。

五分钟带你了解前端开发,以及前端开发的发展机会相关推荐

  1. c++ map用法_Python专题——五分钟带你了解map、reduce和filter

    点击上方蓝字,和我一起学技术.今天是Python专题第6篇文章,给大家介绍的是Python当中三个非常神奇的方法:map.reduce和filter.不知道大家看到map和reduce的时候有没有什么 ...

  2. 五分钟学会python函数_五分钟带你搞懂python 迭代器与生成器

    前言 大家周末好,今天给大家带来的是Python当中生成器和迭代器的使用. 我当初第一次学到迭代器和生成器的时候,并没有太在意,只是觉得这是一种新的获取数据的方法.对于获取数据的方法而言,我们会一种就 ...

  3. 干货:五分钟带你看懂NestedScrolling嵌套滑动机制

    Android NestedScrolling嵌套滑动机制 Android在发布5.0之后加入了嵌套滑动机制NestedScrolling,为嵌套滑动提供了更方便的处理方案.在此对嵌套滑动机制进行详细 ...

  4. 30 分钟带你学透快应用界面开发的最正确姿势

    这篇文章适合快速开发快应用,提高效率,不管你是资深的前端开发,还是刚入门快应用开发的菜鸟,本文都值得你一读.通过阅读本文,我相信一定能节省你的时间,少走很多弯路,将主要的精力放在项目的开发中来. 入门 ...

  5. 五分钟带你了解《操作系统原理》

    前言: (1)计算机系统的层次结构 (2)硬件环境 (3)操作系统结构 (1)进程 (2)进程状态 (3) 中断优先级和中断屏蔽 页式存储管理 在生活中常听说过这种话,如果想做为一个编程高手学习操作系 ...

  6. 五分钟带你玩转Zabbix6.0容器化HA集群

    图片 蔡斯 | Zabbix开源社区签约专家 Zabbix资深玩家,SRE高级运维,架构师.精通服务组件监控.模板制作及告警治理. 擅长领域:Zabbix API定制化开发,对接企业蓝鲸,JMS保垒机 ...

  7. 五分钟带你了解Django框架设计思想!

    Python编程语言的持续火爆,在最新Tiobe编程语言排行榜中位列第五,热度持续增加,尤其是在 AI 和 大数据时代,Python是 AI 和大数据时代的第一开发语言.这已经是一个不争的事实了,唯一 ...

  8. 【十五分钟Talkshow】如何善用你的.NET开发环境

    这一讲的时间大约是25分钟.内容还是有点多了.后期将逐渐规范到15分钟左右一个主题. 摘要提示 在这一讲中,我会介绍以下三个方面的内容 }.NET开发环境简介 }安装和配置Visual Studio ...

  9. 五分钟带你了解!Java程序的编译过程

    Java程序的编译过程 Java 语言的「编译期」其实是一段「不确定」的操作过程.因为它可能是一个前端编译器(如 Javac)把 *.java 文件编译成 *.class 文件的过程:也可能是程序运行 ...

最新文章

  1. 量子位MEET大会正式启动!邀AI企业共同预见智能科技新未来
  2. c++ mat to numpy array
  3. Android移动开发之【Android实战项目】activity生命周期与Java中@Override的作用
  4. laravel5.6 数据库获取数据模式变为’数组‘
  5. python叫什么-什么叫Python运算符重载
  6. 交换基本数据类型的方法swap,并影响到主方法
  7. MySQL常见备份与恢复方案
  8. 人工智能:看似很美,却暗藏泡沫
  9. 动态加载和静态加载及其编译步骤
  10. 关于java中nextline读取空白行的问题
  11. android获取各种系统路径的方法
  12. 智能硬件(3)---各种“地”—— 各种“GND”
  13. JavaScript:数据类型判断的方法
  14. wps linux 字体_WPS Office:Linux 上的 Microsoft Office 的免费替代品 | Linux 中国
  15. 华为 台积电 高通申请_台积电/高通纷纷力挺华为!全面放下姿态:将不再断供华为芯片产品...
  16. 两个list取交集_Java基础面试题-说说你知道的几个Java集合类:list、set、queue、map...
  17. SQL使用技巧(转)
  18. 【问题解决】华硕A450C触控板失灵
  19. @DependsOn
  20. 修改macOS中鼠标滚轮方向

热门文章

  1. Current在Java里面_在C#中相当于Java System.currentTimeMillis()
  2. 外网访问内网Oracle数据库
  3. Microsoft Quantum Katas帮助开发人员探索使用Q#实现量子计算
  4. 硅谷VC想对CIO说这些
  5. vue2.0 非父子组件之间的单一事件通信
  6. IEEE 802.1x 硬件参加的过程
  7. 在JavaScript中创建命名空间的几种写法
  8. Unity3D-5.3.5发布VR项目到Android
  9. 关于request.getParameter(java.lang.String name)
  10. 利用XMLHTTP下载文件