udpate
This commit is contained in:
@@ -1,102 +0,0 @@
|
||||
|
||||
> 本文最初发表于[博客园](http://www.cnblogs.com/smyhvae/p/8776837.html),并在[GitHub](https://github.com/smyhvae/Web)上持续更新**前端的系列文章**。欢迎在GitHub上关注我,一起入门和进阶前端。
|
||||
|
||||
> 以下是正文。
|
||||
|
||||
我前几天写过一篇文章:[《裸辞两个月,海投一个月,从Android转战Web前端的求职之路》](http://www.cnblogs.com/smyhvae/p/8732781.html)。这篇文章讲述了我在转型过程中的亲身经历和感受,不少童鞋私信问我怎么入门前端,于是有了这篇文章。
|
||||
|
||||
|
||||
## Web前端入门的自学路线
|
||||
|
||||
> 新手入门前端,需要学习的**基础内容**有很多,如下。
|
||||
|
||||
一、HTML、CSS基础、JavaScript语法基础。学完基础后,可以仿照电商网站(例如京东、小米)做首页的布局。
|
||||
|
||||
二、JavaScript语法进阶。包括:作用域和闭包、this和对象原型等。相信我,JS语法,永远是面试中最重要的部分。
|
||||
|
||||
三、jQuery、Ajax等。
|
||||
|
||||
四、ES6语法。这部分属于JS新增的语法,面试必问。其中,关于promise、async等内容要尤其关注。
|
||||
|
||||
五、HTML5和CSS3。要熟悉其中的新特性。
|
||||
|
||||
六、canvas。面试时,有的公司不一定会问canvas,靠运气。如果时间不够,这部分的内容可以先不学。
|
||||
|
||||
七、移动Web开发、Bootstrap等。要注意移动开发中的适配和兼容性问题。
|
||||
|
||||
八、前端框架:Vue.js和React。这两个框架至少要会一个。入门时,建议先学Vue.js,上手相对容易。
|
||||
|
||||
九、Node.js。属于加分项,如果时间不够,可以先不学,但至少要知道 node 环境的配置。
|
||||
|
||||
十、自动化工具:构建工具 Webpack、构建工具 gulp、CSS 预处理器 Sass 等。注意,Sass 比 Less 用得多,gulp 比 grunt 用得多。
|
||||
|
||||
十一、前端综合:HTTP协议、跨域通信、安全问题(CSRF、XSS)、浏览器渲染机制、异步和单线程、页面性能优化、防抖动(Debouncing)和节流阀(Throtting)、lazyload、前端错误监控、虚拟DOM等。
|
||||
|
||||
十二、编辑器相关。Sublime Text 是每个学前端的人都要用到的编辑器。另外,前端常见的IDE有两个:WebStorm 和 Visual Studio Code。WebStorm什么都好,可就是太卡顿;VS Code就相对轻量很多。个人总结一下:新手一般用 WebStorm,入门之后,用 VS Code 的人更多。
|
||||
|
||||
|
||||
## 推荐的学习视频
|
||||
|
||||
> 我看过的学习视频,多的数不清。传智播客、尚硅谷、慕课网、极客学院等等,这些只是冰山一角。下面推荐一些。
|
||||
|
||||
温馨提示:不一定是从头到尾看,可以选择性地看。另外,要倍速播放,我一般是用1.5倍的速度播放。
|
||||
|
||||
|
||||
### 传智播客
|
||||
|
||||
传智黑马2018 Web前端全套:
|
||||
|
||||
- 学习路线图:<http://bbs.itheima.com/thread-391250-1-1.html>
|
||||
|
||||
- 视频资源:<http://www.itcast.cn/news/20180209/11421176192.shtml>
|
||||
|
||||
- 官方视频库:<http://yun.itheima.com/course/c135.html>
|
||||
|
||||
PS:上面这三个链接,指向的的是同一个学习资源。
|
||||
|
||||
黑马的视频很新,可以找官方的QQ要配套的PPT和源码。
|
||||
|
||||
|
||||
|
||||
### 尚硅谷
|
||||
|
||||
尚硅谷 2018 Web前端全套:
|
||||
|
||||
- 视频资源:<https://www.52pojie.cn/thread-688171-1-1.html>
|
||||
|
||||
- 官方视频库:<http://www.gulixueyuan.com/course/explore/front>
|
||||
|
||||
PS:上面这两个链接,指向的的是同一个学习资源。
|
||||
|
||||
|
||||
尚硅谷的视频里,讲JS语法和ES6的部分很不错。
|
||||
|
||||
|
||||
## 推荐的技术博客
|
||||
|
||||
- [阮一峰](http://www.ruanyifeng.com/blog/)
|
||||
|
||||
- [张鑫旭](http://www.zhangxinxu.com/wordpress/)
|
||||
|
||||
## 推荐的书籍
|
||||
|
||||
- 《你不知道的JavaScript》
|
||||
|
||||
|
||||
|
||||
|
||||
## 推荐的链接
|
||||
|
||||
待更新。
|
||||
|
||||
|
||||
PS:今天先写到这里。本文内容不定期更新。
|
||||
|
||||
|
||||
## 我的公众号
|
||||
|
||||
想学习<font color=#0000ff>**代码之外的软技能**</font>?不妨关注我的微信公众号:**生命团队**(id:`vitateam`)。
|
||||
|
||||
扫一扫,你将发现另一个全新的世界,而这将是一场美丽的意外:
|
||||
|
||||

|
||||
61
16-前端基础/UserAgent.md
Normal file
61
16-前端基础/UserAgent.md
Normal file
@@ -0,0 +1,61 @@
|
||||
|
||||
|
||||
## 前言
|
||||
|
||||
|
||||
我们知道,在控制台里可以添加很多设备。我们需要点击 edit,手动添加:
|
||||
|
||||
img
|
||||
|
||||
添加时,是根据 User agent 来识别的:
|
||||
|
||||
img
|
||||
|
||||
不同浏览器(包括微信内置的浏览器)的 useragent 信息,是不一样的,我们可以根据 `navigator.userAgent`属性来获取。
|
||||
|
||||
比如说,我们在控制台输入`navigator.userAgent`,如下:
|
||||
|
||||
|
||||
20180425_1656.png
|
||||
|
||||
上图显示,MacOS上的Chrome浏览器的 UserAgent 是:
|
||||
|
||||
```
|
||||
"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/66.0.3359.117 Safari/537.36"
|
||||
```
|
||||
|
||||
|
||||
|
||||
## 不同浏览器的 UserAgent
|
||||
|
||||
iPhone版微信:
|
||||
|
||||
```
|
||||
Mozilla/5.0 (iPhone; CPU iPhone OS 9_3 like Mac OS X) AppleWebKit/601.1.46 (KHTML, like Gecko) Mobile/13E233 MicroMessenger/6.3.15 NetType/WIFI Language/zh_CN
|
||||
```
|
||||
|
||||
Android版微信:
|
||||
|
||||
```
|
||||
Mozilla/5.0 (Linux; Android 5.0.1; GT-I9502 Build/LRX22C; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/43.0.2357.121 Mobile Safari/537.36 MicroMessenger/6.1.0.78_r1129455.543 NetType/WIFI
|
||||
```
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
Android版微信:
|
||||
|
||||
```
|
||||
Mozilla/5.0 (Linux; Android 5.0.1; GT-I9502 Build/LRX22C; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/43.0.2357.121 Mobile Safari/537.36 MicroMessenger/6.1.0.78_r1129455.543 NetType/WIFI
|
||||
```
|
||||
|
||||
## 参考链接
|
||||
|
||||
- [判断微信内置浏览器的UserAgent](http://www.cnblogs.com/7z7chn/p/5370352.html)
|
||||
|
||||
- [微信内置浏览器UserAgent的判断](https://gist.github.com/wjp2013/fff34c063cf0cf227d65)
|
||||
|
||||
|
||||
|
||||
32
16-前端基础/html相关.md
Normal file
32
16-前端基础/html相关.md
Normal file
@@ -0,0 +1,32 @@
|
||||
|
||||
## SSI:服务器端嵌入
|
||||
|
||||
SSI:Server Side Include,服务器端嵌入。
|
||||
|
||||
通俗点讲,就是在本地的html页面中,插入服务器上的文件。即:静态页面中,插入动态的代码。
|
||||
|
||||
比如:
|
||||
|
||||
```html
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<meta http-equiv="X-UA-Compatible" content="ie=edge">
|
||||
<title>Document</title>
|
||||
<style>
|
||||
|
||||
</style>
|
||||
<!--#include virtual="/sinclude/common/head_inc.shtml"-->
|
||||
<!--#include virtual="/sinclude/common/head_shortcut.shtml"-->
|
||||
<!--#include virtual="head.shtml"-->
|
||||
</head>
|
||||
```
|
||||
|
||||
上面的代码中,注释里的代码,就是SSI部分,它加载的是服务器端的html页面。
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user