前端面試問題集(部分)

一、vue框架開發(fā)項(xiàng)目用到了哪些技術(shù)

vue + vuex + vue-router + axios + es6 + webpack

二溯职、vuex 有什么作用

vuex用于程序開發(fā)的狀態(tài)管理雏搂,它采用集中式存儲细疚,管理應(yīng)用的所有組件的狀態(tài)固翰,每一個 Vuex 應(yīng)用的核心就是 store(倉庫)收厨。“store”基本上就是一個容器砸讳,它包含著你的應(yīng)用中大部分的狀態(tài) (state)。
使用:
1界牡、在main.js中引入vuex:import Vuex from 'vuex'簿寂,
然后掛載使用它:Vue.use(Vuex)
2、在main.js中加入:var store = new vuex.Store(){
state:{
count:0
}}

三宿亡、請求后臺數(shù)據(jù)是如何請求的

用axios常遂,請求后臺資源的模塊。npm install axios -S裝好挽荠,然后發(fā)送的是跨域克胳,需在配置文件中config/index.js進(jìn)行設(shè)置。后臺如果是Tp5則定義一個資源路由。js中使用import進(jìn)來,然后.get或.post挚冤。如果成功返回在.then函數(shù)中挠锥,失敗則是在.catch函數(shù)中。

四勋又、vue路由怎么創(chuàng)建和使用
  • 在index.js中引入import vue-router
  • 引入路由頁面:import 路由頁面
  • 掛載使用:Vue.use(Router)
  • 創(chuàng)建路由實(shí)例:export default new Router
  • 在路由實(shí)例中進(jìn)行路由路徑配置:routes[{
    path:Home ,name: ,component: },{},{}]
  • 子路由:children:[{path: ,component: },{},{}]
五、vue組件間怎么傳值
  • 父組件向子組件傳遞數(shù)據(jù):
    只需要在子組件通過v-bind傳入一個值,在子組件中满败,通過props接收,即可完成數(shù)據(jù)的傳遞
  • 子向父傳輸數(shù)據(jù):
    子組件定義一個事件來觸發(fā)叹括,
    父組件需要用到emit函數(shù)來傳參數(shù)算墨。
六、vue組件怎么引用
  1. 編寫子組件
  2. 在需要使用的父組件中通過import引入
  3. 在vue的components中注冊
  4. 在模板中使用
七汁雷、mvvm開發(fā)模式介紹一下

module+view+viewModule净嘀,在MVVM的框架下視圖和模型是不能直接通信的。它們通過ViewModel來通信摔竿,ViewModel通常要實(shí)現(xiàn)一個observer觀察者面粮,當(dāng)數(shù)據(jù)發(fā)生變化,ViewModel能夠監(jiān)聽到數(shù)據(jù)的這種變化继低,然后通知到對應(yīng)的視圖做自動更新熬苍,而當(dāng)用戶操作視圖,ViewModel也能監(jiān)聽到視圖的變化,然后通知數(shù)據(jù)做改動柴底,這實(shí)際上就實(shí)現(xiàn)了數(shù)據(jù)的雙向綁定婿脸。

八、vue中跨域如何處理
  • vue的webpack文件中配置跨域:在根目錄下config的index.js文件中配置柄驻,changeOrigin:true //是否跨域
    target:目標(biāo)接口域名

  • 開發(fā)環(huán)境下狐树,如何做好跨域配置

    首先跨域我們要配置的文件有:config下的index.js

      dev: {
    
          proxyTable: {
    
              '/api': {
    
                      target: 'http://10.1.5.11:8080/',//設(shè)置你調(diào)用的接口域名和端口號
    
                      changeOrigin: true, //跨域
    
                      pathRewrite: {
    
                                 '^/api': '/' //這里理解成用‘/api’代替target里面的地址,
    
                                  后面組件中我們掉接口時直接用api代替
    
                                  比如我要調(diào)用'http://10.1.5.11:8080/xxx/duty?time=2017-07-07 14:57:22'鸿脓,
    
                                  直接寫‘/api/xxx/duty?time=2017-07-07 14:57:22’即可
    
                                  在開發(fā)環(huán)境顯示地址:http://localhost:9600//api/xxx/duty?time=2017-07-07 14:57:22
    
                                      } }
    

config/dev.env.js:

module.exports = merge(prodEnv, {

                                NODE_ENV: '"development"',//開發(fā)環(huán)境

                                API_HOST:"/api/"

                                })
  • 生產(chǎn)環(huán)境中最好的辦法是后端在服務(wù)器端口加個代理抑钟,效果類似開發(fā)時webpack的代理。

axios發(fā)送get post請求問題
發(fā)送post請求時一般都要設(shè)置Content-Type野哭,發(fā)送內(nèi)容的類型在塔,application/json指發(fā)送json對象但是要提前JSON.stringify()一下。application/xxxx-form指發(fā)送拨黔?
a=b&c=d格式蛔溃,可以用qs.stringify()的方法格式化一下,qs在安裝axios后會自動安裝篱蝇,只需要組件里import一下即可贺待。
const postData=JSON.stringify(this.formCustomer);
'Content-Type':'application/json'}

const postData=Qs.stringify(this.formCustomer);//過濾成?&=格式
'Content-Type':'application/xxxx-form'}

九零截、如何判斷用戶的登錄狀態(tài)

vuex + localstorage (用于長期登錄+判斷用戶是否已登錄+適合長期保存在本地的數(shù)據(jù))

十麸塞、頁面已經(jīng)更新,但是數(shù)據(jù)沒有變化瞻润,瀏覽器緩存如何處理
  • 其實(shí)解決這個問題很簡單喘垂,緩存是通過文件名標(biāo)記緩存的內(nèi)容的。在你更新了網(wǎng)站的css文件內(nèi)容后绍撞,在更換一下css的文件名就可以了正勒。如原先html中的css調(diào)用語句如下:

<link rel="stylesheet" href="style.css" type="text/css" media="screen"/>

改一下css文件名:

<link rel="stylesheet" href="styleV2.css" type="text/css" media="screen"/>

  • 給css/js文件加個版本號
    第一種方法修改css/js后改文件名確實(shí)麻煩,所以我們可以加載css/js語句中加入版本號(即css/js鏈接中傻铣?后面的內(nèi)容)就可以了章贞。如原先的HTML中的css調(diào)用語句如下:

<link rel="stylesheet" href="css/style.css?v=201708" />
將css文件的版本號改成新的:

<link rel="stylesheet" href="css/style.css?v=201709" />

十一、用戶如果一直提交數(shù)據(jù)非洲,怎么辦

可以將提交的按鈕狀態(tài)更改鸭限,提交之后按鈕變?yōu)椴豢捎谩?/p>

十二、get和post請求方式區(qū)別
  • get 用的是瀏覽器的url地址傳輸两踏,傳輸數(shù)據(jù)有限败京,內(nèi)容公開,不安全
  • post 用的是請求體傳輸梦染,比較安全赡麦,傳輸?shù)臄?shù)據(jù)也比較大
十三朴皆、git如何處理版本沖突和新建合并分支
  • 處理沖突:
    先把云上的pull下來,然后在本地合并修改之后泛粹,再commit遂铡,再push到云上。
  • 創(chuàng)建合并分支:
  1. git branch xxx (創(chuàng)建分支)
  2. git checkout xxx (檢出)
  3. git merge (合并分支)
十四晶姊、數(shù)據(jù)雙向綁定實(shí)現(xiàn)和原理

用v-module實(shí)現(xiàn)的扒接,VUE實(shí)現(xiàn)雙向數(shù)據(jù)綁定的原理就是利用了 Object.defineProperty() 這個方法重新定義了對象獲取屬性值(get)和設(shè)置屬性值(set)的操作來實(shí)現(xiàn)的。

十五们衙、webpack有什么作用钾怔,配置
  • 可以自動編譯TypeScript為JavaScript
  • webpack-cli/vue-cli 自動生成配置文件
  • webpack是一個模塊打包器,強(qiáng)調(diào)的是一個前端模塊化方案蒙挑,更側(cè)重模塊打包蒂教,我們可以把開發(fā)中的所有資源都看成是模塊,通過loader和plugin對資源進(jìn)行處理脆荷。
  • webpack打包原理:把所有依賴打包成一個 bundle.js 文件,通過代碼分割成單元片段并按需加載懊悯。
十六蜓谋、es6的一些寫法
  • let和const:使用let來聲明一個值會被改變的變量,而使用const來聲明一個值不會被改變的變量炭分,也可以稱之為常量桃焕。
  • 可省略 :function,更簡便捧毛,
  • 箭頭函數(shù)中观堂,它沒有自己的this,函數(shù)體內(nèi)的this對象呀忧,就是定義時所在的對象师痕,而不是使用時所在的對象。
  • 模板字符串:是為了解決使用+號拼接字符串的不便利而出現(xiàn)的而账。 使用 `` 將整個字符串包裹起來胰坟,而在其中使用 ${} 來包裹一個變量或者一個表達(dá)式。
  • 來看看ES6的函數(shù)默認(rèn)值寫法:
    function add(x = 20, y = 30) {
    return x + y;
    }
    console.log(add());
  • 在ES6中用...來表示展開運(yùn)算符泞辐,它可以將數(shù)組方法或者對象進(jìn)行展開笔横。例如:
    const arr1 = [1, 2, 3];
    const arr2 = [...arr1, 10, 20, 30];
    這樣,arr2 就變成了[1, 2, 3, 10, 20, 30];
十七咐吼、H5 的一些新特性
  • 新增了一些語義化標(biāo)簽:header吹缔、footer、nav锯茄、aside厢塘、article、audio、video等

  • 媒體查詢 @media 可以做出響應(yīng)式頁面

  • 新表單元素的引入(智能表單俗冻,對自動輸入的內(nèi)容做基本的校驗(yàn)):input:type=number(數(shù)字)礁叔、email(郵箱)、url(地址)迄薄、range(滑塊)琅关、date(日期)等,placeholder(占位符)讥蔽、require(必填項(xiàng))涣易。

  • 本地存儲:webstorage:sessionStorage和localStorage

  1. sessionStorage(會話期間有效,關(guān)閉瀏覽器窗口就失效冶伞,容量5M新症,不同頁面或標(biāo)簽頁面間無法共享,適用于敏感賬號一次性登錄)
  2. localStorage(本地存儲永久有效响禽,多窗口共享徒爹,容量5M,用于長期登錄+判斷用戶是否已登錄+適合長期保存在本地的數(shù)據(jù))
  • 獲取地理位置的api:Window.navigator.geolocation.getCurrentPosition(success,error)
十八芋类、Html的語義化

1隆嗅、在沒有css的渲染下,依然能夠清晰的看出頁面的結(jié)構(gòu)侯繁,方便開發(fā)人員開發(fā)胖喳。
2、語義化更有可讀性贮竟,便于團(tuán)隊(duì)開發(fā)和維護(hù)丽焊。
3、便于seo咕别,便于搜索引擎的搜索技健。

十九、cookie惰拱、sessionSttorage凫乖、localStory區(qū)別
  • 數(shù)據(jù)存儲大小
    cookie:4kb
    webStorge:5mb
  • 數(shù)據(jù)存儲有效期限
    cookie:根據(jù)自己的設(shè)置時間
    sessionStorage:關(guān)閉窗口后失效
    localStorage:永久有效除非js刪除或者瀏覽器刪除
  • 作用域
    cookie和localStorage是在同源窗口,同一個瀏覽器共享的弓颈,sessionStorage只在同一個標(biāo)簽頁共享帽芽。
二十、從輸入網(wǎng)址到頁面加載發(fā)生了什么

大概分為以下過程
DNS解析
TCP連接
發(fā)送HTTP請求
服務(wù)器處理請求并返回HTTP報文
瀏覽器解析渲染頁面
連接結(jié)束

二十一翔冀、圖片很多如何進(jìn)行優(yōu)化

可以進(jìn)行懶加載或者是分頁加載导街。

二十二、移動端適配怎么配置

viewport纤子,三個屬性
<meta name="viewport" content="width=device-width, initial-scale=1.0,user-scalable=0"

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末搬瑰,一起剝皮案震驚了整個濱河市款票,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌泽论,老刑警劉巖艾少,帶你破解...
    沈念sama閱讀 207,113評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異翼悴,居然都是意外死亡缚够,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評論 2 381
  • 文/潘曉璐 我一進(jìn)店門鹦赎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來谍椅,“玉大人,你說我怎么就攤上這事古话〕裕” “怎么了?”我有些...
    開封第一講書人閱讀 153,340評論 0 344
  • 文/不壞的土叔 我叫張陵陪踩,是天一觀的道長杖们。 經(jīng)常有香客問我,道長肩狂,這世上最難降的妖魔是什么胀莹? 我笑而不...
    開封第一講書人閱讀 55,449評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮婚温,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘媳否。我一直安慰自己栅螟,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評論 5 374
  • 文/花漫 我一把揭開白布篱竭。 她就那樣靜靜地躺著力图,像睡著了一般。 火紅的嫁衣襯著肌膚如雪掺逼。 梳的紋絲不亂的頭發(fā)上吃媒,一...
    開封第一講書人閱讀 49,166評論 1 284
  • 那天,我揣著相機(jī)與錄音吕喘,去河邊找鬼赘那。 笑死,一個胖子當(dāng)著我的面吹牛氯质,可吹牛的內(nèi)容都是我干的募舟。 我是一名探鬼主播,決...
    沈念sama閱讀 38,442評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼闻察,長吁一口氣:“原來是場噩夢啊……” “哼拱礁!你這毒婦竟也來了琢锋?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,105評論 0 261
  • 序言:老撾萬榮一對情侶失蹤呢灶,失蹤者是張志新(化名)和其女友劉穎吴超,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體鸯乃,經(jīng)...
    沈念sama閱讀 43,601評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡鲸阻,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了飒责。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片赘娄。...
    茶點(diǎn)故事閱讀 38,161評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖宏蛉,靈堂內(nèi)的尸體忽然破棺而出遣臼,到底是詐尸還是另有隱情,我是刑警寧澤拾并,帶...
    沈念sama閱讀 33,792評論 4 323
  • 正文 年R本政府宣布揍堰,位于F島的核電站,受9級特大地震影響嗅义,放射性物質(zhì)發(fā)生泄漏屏歹。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評論 3 307
  • 文/蒙蒙 一之碗、第九天 我趴在偏房一處隱蔽的房頂上張望蝙眶。 院中可真熱鬧,春花似錦褪那、人聲如沸幽纷。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽友浸。三九已至,卻和暖如春偏窝,著一層夾襖步出監(jiān)牢的瞬間收恢,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評論 1 261
  • 我被黑心中介騙來泰國打工祭往, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留伦意,地道東北人。 一個月前我還...
    沈念sama閱讀 45,618評論 2 355
  • 正文 我出身青樓硼补,卻偏偏與公主長得像默赂,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子括勺,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評論 2 344

推薦閱讀更多精彩內(nèi)容

  • 一:什么是閉包缆八?閉包的用處曲掰? (1)閉包就是能夠讀取其他函數(shù)內(nèi)部變量的函數(shù)。在本質(zhì)上奈辰,閉包就 是將函數(shù)內(nèi)部和函數(shù)外...
    xuguibin閱讀 9,523評論 1 52
  • vue是什么栏妖? vue是構(gòu)建數(shù)據(jù)驅(qū)動的web界面的漸進(jìn)式框架。Vue.js 的目標(biāo)是通過盡可能簡單的 API 實(shí)現(xiàn)...
    九四年的風(fēng)閱讀 8,695評論 2 131
  • 1奖恰、active-class是哪個組件的屬性吊趾?嵌套路由怎么定義?答:vue-router模塊的router-lin...
    jane819閱讀 1,740評論 0 15
  • 基于Vue的一些資料 內(nèi)容 UI組件 開發(fā)框架 實(shí)用庫 服務(wù)端 輔助工具 應(yīng)用實(shí)例 Demo示例 element★...
    嘗了又嘗閱讀 1,140評論 0 1
  • vue-cli搭建項(xiàng)目 確保安裝了node與npm 再目標(biāo)文件夾下打開終端 執(zhí)行cnpm i vue-cli -g...
    Akiko_秋子閱讀 3,214評論 1 22