問題描述
部分用戶訪問網站時,檢測日誌出現url(http://www.xxx.cn/browserconfig.xml)這個返回404.網上一搜才知道,這是ie11的磁貼(https://msdn.microsoft.com/library/dn455106(v=vs.85).aspx)配置文件。當用戶固定站點時,IE11 會查找名爲 browserconfig.xml 的包含獨立通知文件(磁貼架構文件)的 URL 的文件,並讓 Windows 以指定的時間間隔獲取該文件。因爲我們網站沒有配置所以,部分固定了站點的用戶訪問網站時,ie11獲取不到磁貼配置文件,所以返回了404.
解決辦法
1、很簡單,那就是配置browserconfig.xml文件,並放到站點根目錄下,並且通過頁面 <head> 部分中的圖元元素<meta name="msapplication-config" content="browserconfig.xml" />指向這個文件。在這裏注意改配置文件名稱要用默認的browserconfig,不然IE仍然找不到。
2、如何配置?https://msdn.microsoft.com/library/dn455106(v=vs.85).aspx ,官方文檔介紹了三種方法配置。分別是(http://samples.msdn.microsoft.com/iedevcenter/PinnedSites/default.html):
直接在heade裏通過定義元數據的方式(http://www.buildmypinnedsite.com/)
第二是通過配置xml的方式(這種方式最好,尤其要做動態網站的)
第三種是通過js來調用動態磁貼架構文件
注意事項
雖然對着官方文檔配置很簡單,但是還是有一些小問題要注意的。
- header裏面通過meta定義的元數據名稱一定要是ie11默認的名稱。
由於ie磁貼只是針對win8,win8.1,win10用戶,所以在配置完測試的時候還是有些坑的。用windows默認IE打開網址。
成功後的圖片
網站元數據
推薦閱讀 http://blog.csdn.net/freshlover/article/details/25322839
http://www.haorooms.com/post/html_meta_ds
移動端viewport標籤
<meta name="viewport"
content="
height = [pixel_value | device-height] ,
width = [pixel_value | device-width ] ,
initial-scale = float_value ,
minimum-scale = float_value ,
maximum-scale = float_value ,
user-scalable = [yes | no] ,
target-densitydpi = [dpi_value | device-dpi | high-dpi | medium-dpi | low-dpi]
"
/>
含義如下:
width
控制 viewport 的大小,可以指定的一個值或者特殊的值,如 device-width 爲設備的寬度(單位爲縮放爲 100% 時的 CSS 的像素)。
height
和 width 相對應,指定視窗的高度。
target-densitydpi
一個屏幕像素密度是由屏幕分辨率決定的,通常定義爲每英寸點的數量(dpi)。Android支持三種屏幕像素密度:低像素密度,中像素密度,高像素密度。一個低像素密度的屏幕每英寸上的像素點更少,而一個高像素密度的屏幕每英寸上的像素點更多。Android Browser和WebView默認屏幕爲中像素密度。
下面是 target-densitydpi 屬性的 取值範圍
device-dpi –使用設備原本的 dpi 作爲目標 dp。 不會發生默認縮放。
high-dpi – 使用hdpi 作爲目標 dpi。 中等像素密度和低像素密度設備相應縮小。
medium-dpi – 使用mdpi作爲目標 dpi。 高像素密度設備相應放大, 像素密度設備相應縮小。 這是默認的target density.
low-dpi -使用mdpi作爲目標 dpi。中等像素密度和高像素密度設備相應放大。
<value> – 指定一個具體的dpi 值作爲target dpi. 這個值的範圍必須在70–400之間。
爲了防止Android Browser和WebView 根據不同屏幕的像素密度對你的頁面進行縮放,你可以將viewport的target-densitydpi 設置爲 device-dpi。當你這麼做了,頁面將不會縮放。相反,頁面會根據當前屏幕的像素密度進行展示。在這種情形下,你還需要將viewport的width定義爲與設備的width匹配,這樣你的頁面就可以和屏幕相適應。
initial-scale
初始縮放。即頁面初始縮放程度。這是一個浮點值,是頁面大小的一個乘數。例如,如果你設置初始縮放爲“1.0”,那麼,web頁面在展現的時候就會以target density分辨率的1:1來展現。如果你設置爲“2.0”,那麼這個頁面就會放大爲2倍。
maximum-scale
最大縮放。即允許的最大縮放程度。這也是一個浮點值,用以指出頁面大小與屏幕大小相比的最大乘數。例如,如果你將這個值設置爲“2.0”,那麼這個頁面與target size相比,最多能放大2倍。
user-scalable
用戶調整縮放。即用戶是否能改變頁面縮放程度。如果設置爲yes則是允許用戶對其進行改變,反之爲no。默認值是yes。如果你將其設置爲no,那麼minimum-scale 和 maximum-scale都將被忽略,因爲根本不可能縮放。
所有的縮放值都必須在0.01–10的範圍之內。
例:
(設置屏幕寬度爲設備寬度,禁止用戶手動調整縮放)
<meta name="viewport" content="width=device-width,user-scalable=no" />
(設置屏幕密度爲高頻,中頻,低頻自動縮放,禁止用戶手動調整縮放)
<meta name="viewport" content="width=device-width,target-densitydpi=high-dpi,initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no"/>
另外,iOS 7.1的Safari爲meta標籤新增minimal-ui屬性,在網頁加載時默認隱藏地址欄與導航欄
<meta name="viewport" content="minimal-ui">
此時點擊頂欄區域便能切換爲顯示地址欄、導航欄,再點擊頁面主體區域則又使之隱藏。