这是一个2019年你成为前端,后端或全栈开发者的进阶指南:
1、你不需要学习所有的技术成为一个web开发者
2、这个指南只是通过简单分类列出了技术选项
3、我将从我的经验和参考中给出建议
4、首选我们会介绍通用的知识, 最后介绍2019年的Web的一些趋势
1、基础前端开发者
1.1 HTML & CSS
![1240](https://i-blog.csdnimg.cn/blog_migrate/1f738758015e6e8bceb2f67f8f28c9ab.webp?x-image-process=image/format,png)
最基础的知识:
- 语义化的HTML元素
- 基础的CSS语法
- Flexbox & Grid
- CSS变量
- 浏览器开发者工具
1.2 响应式布局
![1240](https://i-blog.csdnimg.cn/blog_migrate/2118b81e5d229b1f5236ad94289fbaab.webp?x-image-process=image/format,png)
响应式设计将不再是网页的加分项, 而是必须的
- 设置viewport
- 非固定宽度
- 媒体查询
- 使用 rem 替代 px
- 移动优先,柱状显示
1.3 基础的部署工作
![1240](https://i-blog.csdnimg.cn/blog_migrate/b480533e912e99a96d9979c76a3b6078.webp?x-image-process=image/format,png)
学会如何部署一个静态网站到服务器
- 注册一个域名(NameCheap, Google Domains)
- 管理共享主机或虚拟机(Inmotion, Hostgator, Bluehost)
- FTP, SFTP 文件上传(Filezilla, Cyberduck)
- 静态页面托管(Netlify, Github Pages)
1.4 SASS预处理器
![1240](https://i-blog.csdnimg.cn/blog_migrate/e2a9c7fbbb8577477655be4f8edef15d.webp?x-image-process=image/format,png)
虽然不是必须的, 但是推荐去学, 基础知识的掌握很简单
- 结构化CSS
- 变量
- 嵌套样式表
- Minxins & 函数
- 继承
1.5 原生JavaScript语法
![image](https://i-blog.csdnimg.cn/blog_migrate/366030bb1a726b8536a2f2bebbe0d2c2.webp?x-image-process=image/format,png)
不使用任何框架和库区学习原生的JS语法
- 数据类型, 函数, 条件判断, 循环, 凑总府
- DOM操作和事件
- JSON
- Fetch
- ES6+(箭头函数, Promise, async/await, 解构)
1.6 满足了基本的前端开发者的条件
![image](https://i-blog.csdnimg.cn/blog_migrate/0ce0e40ed58babc43ccc424d5b45e48a.webp?x-image-process=image/format,png)
- 构建静态站点
- 构建UI布局(拿到设计图能够使用HTML/CSS还原)
- 添加一些交互功能
- 部署和维护网站
现在能找到最低水平的Web开发工作, 但是这是远远不够的....
2、一个成熟的前端开发者
2.1 HTML & CSS框架
![image](https://i-blog.csdnimg.cn/blog_migrate/1855541ba23dc84a8115034fafc27172.webp?x-image-process=image/format,png)
HTML/CSS框架目前没有以前那么有意义, 但是我还是介意你选择一个学习(这里作者想隐射的应该是, 在jquery时代, HTML/CSS框架的学习是必须的).
- BootStrap
- Materialize
- Bulma
2.2 Git和其他工作流工具
![image](https://i-blog.csdnimg.cn/blog_migrate/91753707f764c3c0e80327d47601642b.webp?x-image-process=image/format,png)
Git绝对是每一个Web开发者必须掌握的工具, 这里也有一些其他的工作流工具的建议.,
- 基础的命令行( touch, cd, mkdir什么的总得会, 命令行在下面的工具中都会用到)
- Git(版本控制)
- NPM 或 Yarn(包管理)
- Webpack 或者 Parcel(打包工具)
- Gulp 或者 Grunt(任务管理和构建工具)
- 编辑器插件(ESLint, Prettier, Live Server等)
2.3 前端框架
![image](https://i-blog.csdnimg.cn/blog_migrate/7b72822827fac8f875b4db22fde827f5.webp?x-image-process=image/format,png)
学习一个前端框架在目前前端开发中是必须的.
- 在大公司开发中非常流行
- 更多的交互 & 有趣的UI组件
- 组件化 & 模块化前端代码
- 对团队有利
2.4 状态管理
![image](https://i-blog.csdnimg.cn/blog_migrate/90d0ff86feea93886e9ee025e2b3fc1a.webp?x-image-process=image/format,png)
对于使用框架的大型前端项目, 你也许需要使用状态管理工具去管理你的应用级的状态
- Redux(Context API)
- Apollo(GraphQL Client)
- Vuex
- NgRx
2.5 满足一个成熟的前端开发者条件
![image](https://i-blog.csdnimg.cn/blog_migrate/acfd634e0dc1e982eed92285010fab8b.webp?x-image-process=image/format,png)
- 构建一个优秀的前端应用
- 流畅和稳定的前端工作流
- 多人开发 & 熟练使用Git
- 请求后端API & 前端数据响应
满足以上条件, 你能够顺利的找到一个前端的工作并干得很出色~
3、全栈开发工程师
3.1 学习一门后端语言
![image](https://i-blog.csdnimg.cn/blog_migrate/f68d61344fe526e7e6e9bef3eacd62ec.webp?x-image-process=image/format,png)
成为一个全栈工程师或软件工程师, 你将需要学习一个服务端语言和相关技术
学习的顺序:
- 基础的后端语言语法
- 数据结构和工作流
- 包管理
- HTTP/路由
3.2 服务端框架
![image](https://i-blog.csdnimg.cn/blog_migrate/6a3796bcd882a3d35e0f44d06583cab7.webp?x-image-process=image/format,png)
不要重复造轮子, 学习一门框架去构建更好和更快的应用
- Node.js(Express, Koa, Adonis)
- Python(Django, Flask)
- PHP(Laravel, Symfony)
- C# (ASP.NET)
3.3 数据库
![image](https://i-blog.csdnimg.cn/blog_migrate/a4dc061182f6c6846c17f3feef11db65.webp?x-image-process=image/format,png)
绝大多数觉得应用都会使用到数据库, 这里有一些选择:
- 关系型数据库(MySQL, PostgreSQL, MS SQL)
- 非关系型数据库 (MongoDB, Counchbase)
- 云服务 (Firebase, AWS, Azure, DocumentDB)
- 轻量级(SQLite, NeDB, Redis)
3.4 服务端渲染
![image](https://i-blog.csdnimg.cn/blog_migrate/59e087e99726e62228c3407b73f962f2.webp?x-image-process=image/format,png)
像React, Vue 和 Angular等端架都可以进行服务端渲染
- Next.js(React)
- Nuxt(Vue)
- Angular Universal(Angular)
3.5 内容管理系统
![image](https://i-blog.csdnimg.cn/blog_migrate/4d16bfc6419007b060663d0f5d2effd3.webp?x-image-process=image/format,png)
内容管理系统允许快速开发并为您的客户提供更新内容的能力. 在你需要快速开发网站的时候, 它们是很适合的. 特别是对于自由开发者.
- 基于PHP的 (Wordpress, Drupal)
- 基于JS的 (Ghost, Keystone)
- 基于Python的 (Mezzazine)
- 基于.Net的 (Piranha, Orchard CMS)
3.6 DevOps 和部署
![image](https://i-blog.csdnimg.cn/blog_migrate/c8a3c6c4a019a1710444ea61be21c1fe.webp?x-image-process=image/format,png)
学习语言和框架是一回事, 但是安装环境, 测试和部署有事另外一回事
- 部署 (Linux, SSH, Git, Nginx, Apache)
- 平台 (Digital Ocean, AWS, Heroku, Azure)
- 可视化(Docker, Vagrant)
- 测试 (单元测试, 集成测试, 函数式测试, 系统测试)
3.7 满足全栈工程师的条件
![image](https://i-blog.csdnimg.cn/blog_migrate/d32d88fe1c050a3a7b1db33f4a3a5c1e.webp?x-image-process=image/format,png)
- 设置全栈的开发环境和工作流
- 构建后端服务API和微服务
- 数据库操作
- 能够独立开发应用(前端和服务端)
- 部署到云端(SSH, Git, Servers等等)
4、2019技术趋势和其他
4.1 原生应用开发
![image](https://i-blog.csdnimg.cn/blog_migrate/f18781d737a5d11e5ffe382708329612.webp?x-image-process=image/format,png)
- React Native(使用React构建原生应用)
- NativeScirpt(Angular, Typescript, JavaScript)
- Ionic (HTML/CSS/JS 实现混合应用)
- Flutter (使用Dart语言开发原生应用的移动端SDK)
- Xamarin (使用C#开发的移动端应用)
4.2 使用Electron开发桌面应用
![image](https://i-blog.csdnimg.cn/blog_migrate/0adc397a90182727b69c79f2a906bad5.webp?x-image-process=image/format,png)
Electron是一个使用JavaScript构建跨平台的桌面应用工具.
- 使用到了 Chromium内核和Node.js
- 兼容Windows, Mac & Linux
- 崩溃报告, 调试和性能分析
4.3 GraphQL & Apollo
GraphQl是对于API的一种革命性新方法,查询语言比标准RESET严格得多
![image](https://i-blog.csdnimg.cn/blog_migrate/9e77913d43765e3cdd8ed4a3e8577603.webp?x-image-process=image/format,png)
- 只查询你想要的东西
- 前端和后端可以合作得更为顺利
- 查询语句非常简单且很像JSON语句
- Apollo是一个发送请求到GraphQL的客户端
- 使用的是Gatsby静态站点生成器
4.4 TypeScript
![image](https://i-blog.csdnimg.cn/blog_migrate/b9296fa189f3e210936e18d32ad98a0e.webp?x-image-process=image/format,png)
TypeScript是一个JavaScript的超集, 它添加了静态类型等很多特性.
- 变量, 函数等类型
- 类
- 其他ES6的特性
- 在Angular中被使用到, 同时也可以在React和Vue中被使用
4.5 无服务架构
![image](https://i-blog.csdnimg.cn/blog_migrate/4ea101e1a0fb5e46816d9b34aa2efa4f.webp?x-image-process=image/format,png)
无需创建和管理自己的服务器
- 使用第三服务执行“无服务器功能”
- 例如 AWS, Netify & Firebase
- 在Gatsby静态站点生成器很流行
- 无服务框架
4.6 AI和机器学习
![image](https://i-blog.csdnimg.cn/blog_migrate/36430a89b203fd441770b6a04a9662f3.webp?x-image-process=image/format,png)
AI和机器学习已经被广泛应用在所有的程序和技术中, 甚至包括web开发中.
- 机器学习可以允许Web应用程序随时间进行调整
- 虽然AI还有很长的路要走, 但是我们会看到它会更多的用在web中
- 虽然目前绝大多数都是Python写的, 但也有Tensorflow.js和Brain.js这些JS的库
4.7 区块链技术
![image](https://i-blog.csdnimg.cn/blog_migrate/1d5899fa6b314704103ff5a74f9286ea.webp?x-image-process=image/format,png)
现在许多公司使用区块链技术进行数字交易, 因为它们更安全和有效率.
- Solidity(一门智能合约的编程语言)
- Mist(以太坊开发的浏览器, 用于发送交易和合约)
- 比特币API(可以构建app和整和比特币的区块链开发)
4.8 PWA
![image](https://i-blog.csdnimg.cn/blog_migrate/b59dbb169c90389b646ee86093b77298.webp?x-image-process=image/format,png)
Progressive Web Apps是一个web app但是在功能和样式上给用户带来原生应用使用体验的一项技术.
- 响应式
- 在离线环境下也能够提供服务
- 类似App的交互
- HTTPS
- 可靠, 迅速, 更好
4.9 Web Assembly
![image](https://i-blog.csdnimg.cn/blog_migrate/f37cc080e28f117ec0abd0e251eb3b67.webp?x-image-process=image/format,png)
类似汇编的二进制格式的代码可以被浏览器执行. 可以使用类似C/c++和Rust等高级语言进行编写.
- 比JavaScript执行效率快
- 更安全 - 强制的浏览器同源和安全协议
- 开放 & 可调试
自己是一个五年的前端工程师
这里推荐一下我的前端学习交流群:731771211,里面都是学习前端的从最基础的HTML+CSS+JS【炫酷特效,游戏,插件封装,设计模式】到移动端HTML5的项目实战的学习资料都有整理,送给每一位前端小伙伴。2019最新技术,与企业需求同步。好友都在里面学习交流,每天都会有大牛定时讲解前端技术!
点击: 加入
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/69901074/viewspace-2564503/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/69901074/viewspace-2564503/