如何去除vue項目中的#及其ie9相容性,

來源:互聯網
上載者:User

如何去除vue項目中的#及其ie9相容性,

一、如何去除vue項目中訪問地址的#

vue2中在路由配置中添加mode(vue-cli建立的項目在src/router/index.js)

export default new Router({ mode: 'history', routes: [  {   path: '/',   name: 'menu',   component: menu,   children: [    {     path: 'organization',     component: organization,     children: [      {       path: '',       redirect: 'organizationSub'      },      {       path: 'organizationSub',       component: organizationSub      }     ]    },    {     path: 'user',     component: user    },    {     path: 'role',     component: role    }   ]  } ]})

二、vue路由原理

2.1  hash模式:vue-router預設的路由模式。

vue開發的單頁面應用,html只有一個,切換時url的變化通過url的hash模式類比完整的url。

2.2  history模式:vue2中配置 mode: 'history'。

利用history.pushState API完成url的跳轉

HTML5 History 模式官網介紹:https://router.vuejs.org/zh-cn/essentials/history-mode.html

三、注意事項

不過這種模式要玩好,還需要後台配置支援。因為我們的應用是個單頁用戶端應用,如果後台沒有正確的配置,當使用者在瀏覽器直接存取 http://oursite.com/user/id 就會返回 404,這就不好看了。

所以呢,你要在服務端增加一個覆蓋所有情況的候選資源:如果 URL 匹配不到任何靜態資源,則應該返回同一個 index.html 頁面,這個頁面就是你 app 依賴的頁面。

vue-router官網中有介紹,也有後台配置範例:https://router.vuejs.org/zh-cn/essentials/history-mode.html

四、相容性

經過測試,mode: 'history'在ie9下不生效,若vue項目需要相容ie9,且後台對訪問地址有嚴格校正,不建議使用此種模式。若是內容有錯誤或遺漏,歡迎大家批評指正~

以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支援幫客之家。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.