搜尋
首頁web前端html教學分享viewport屬性解決移動端豎屏切橫屏字體被重置的問題實例

本文分享的是viewport屬性解決行動端垂直螢幕切割橫屏字體被重置的問題。在最初做的時候因為一直沒有在手機上實測頁面,導致後來寫了好些頁面後實測發現頁面特別小,幾乎都看不見。

原因是每個行動裝置都是自己預設的視口寬度。

視窗:在行動裝置瀏覽器當中有兩種視窗:可見視窗(裝置螢幕大小)和瀏覽器視窗(網頁寬度)。

拿iphone4s來說,它的螢幕是320*480的,但是它卻能展示980像素寬度的內容(iphone預設都是980),所以你把網頁放到行動端展示就相當於縮小了980/320。手機這樣做的目的是可以顯示更多的東西,但是結果就是在PC端做好的頁面到了移動端就像螞蟻一樣小!

行動端有一個meta標籤:viewport,你可以用這個標籤設定瀏覽器視窗寬度和可見視窗寬度一樣。

<meta name="viewport" content="width=device-width">

對於一些不支援viewport的古老的行動裝置瀏覽器(嗯,也許還有,例如黑莓),可以使用如下程式碼

<meta name="HandheldFriendly" content="true">

不過我覺得現在應該沒多少人用這個,一般就寫第一行就行了。

說到viewport,他其實還有一些其他屬性

initial-scale:初始縮放比例

maximum-scale:允許縮放的最大比例

minimum-scale:允許縮放的最小比例

user-scalable:是否允許手動縮放

這些屬性有什麼用呢?

行動裝置在垂直螢幕切換到橫螢幕的時候字體會被重置,會變得很大,如何解決呢?

只需要這樣設定

<meta name="viewport" content="width=device-width, initial-scale=1,minimum-scale=1, maximum-scale=1>

這樣設定頁面預設縮放小比例是1,允許縮放也是1-1,相當於禁止縮放,瀏覽器只會按照樣式定義的字體大小渲染。

你也許會看到這種寫法。

<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" >

但其實當你使用user-scalable=no 這個屬性的時候minimum-scale=1,maximum-scale=1已經被忽略掉了,因為你已經禁止縮放了。

在其他地方找到了一些更具體的說法:

1)、user-scalable=no一定可以保證頁面不可以縮放嗎? NO,有些瀏覽器不吃這套,還有一招就是minimum-scale=1.0, maximum-scale=1.0 最大與最小縮放比例都設為1.0就可以了。

2)、initial-scale=1.0   初始縮放比例受user-scalable控制嗎?不一定,有些瀏覽器會將user-scalable理解為使用者手動縮放,如果user-scalable=no,initial-scale將無法生效。

3)、手機頁面可以觸摸移動,但是如果有需要禁止此操作,就是頁面寬度等於螢幕寬度是頁面剛好適應螢幕才可以保證頁面不能移動。

4)、如果頁面是經過縮小適應螢幕寬度的,會出現一個問題,當文字方塊被啟動(取得焦點)時,頁面會放大至原來尺寸。

 所以為了保險起見,建議使用第二種寫法。

當然,這樣做的壞處就是禁止使用者進行縮放,在《web開發實戰》中有一個折衷的辦法,有興趣的可以去看下,這裡就不在敘述。

一點點題外話:

在CSS3中有一個屬性:-webkit-text-size-adjust。

這個屬性也是禁止字體縮放,這個屬性的好處是可以自訂範圍,可以依照專案需求設定。

 要注意的是這個屬性的作用是停用Webkit核心瀏覽器的文字大小調整功能而不是對頁面縮放控制。中文版chrome瀏覽器字型最小限制是12px。

不過由於該屬性被濫用,在幾年前桌面瀏覽器已經不支持了,所以我也沒有真正去用過,都是在其他資料上看到的。

【相關推薦】

1. 特別推薦「php程式設計師工具箱」V0.1版本下載

2. 關於viewport相容性問題的實例程式碼

#3. viewport專題:深入理解css中響應式Web 設計-viewport

4. HTML5中Viewport的參數介紹以及使用方法

#

以上是分享viewport屬性解決移動端豎屏切橫屏字體被重置的問題實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
HTML的未來:進化和趨勢HTML的未來:進化和趨勢May 13, 2025 am 12:01 AM

HTML的未來將朝著更加語義化、功能化和模塊化的方向發展。 1)語義化將使標籤更明確地描述內容,提升SEO和無障礙訪問。 2)功能化將引入新元素和屬性,滿足用戶需求。 3)模塊化將支持組件化開發,提高代碼復用性。

為什麼HTML屬性對Web開發很重要?為什麼HTML屬性對Web開發很重要?May 12, 2025 am 12:01 AM

htmlattributesarecrucialinwebdevelopment forcontrollingBehavior,外觀和功能

Alt屬性的目的是什麼?為什麼重要?Alt屬性的目的是什麼?為什麼重要?May 11, 2025 am 12:01 AM

alt屬性是HTML中標籤的重要部分,用於提供圖片的替代文本。 1.當圖片無法加載時,alt屬性中的文本會顯示,提升用戶體驗。 2.屏幕閱讀器使用alt屬性幫助視障用戶理解圖片內容。 3.搜索引擎索引alt屬性中的文本,提高網頁的SEO排名。

HTML,CSS和JavaScript:示例和實際應用HTML,CSS和JavaScript:示例和實際應用May 09, 2025 am 12:01 AM

HTML、CSS和JavaScript在網頁開發中的作用分別是:1.HTML用於構建網頁結構;2.CSS用於美化網頁外觀;3.JavaScript用於實現動態交互。通過標籤、樣式和腳本,這三者共同構築了現代網頁的核心功能。

如何在標籤上設置lang屬性?為什麼這很重要?如何在標籤上設置lang屬性?為什麼這很重要?May 08, 2025 am 12:03 AM

設置標籤的lang屬性是優化網頁可訪問性和SEO的關鍵步驟。 1)在標籤中設置lang屬性,如。 2)在多語言內容中,為不同語言部分設置lang屬性,如。 3)使用符合ISO639-1標準的語言代碼,如"en"、"fr"、"zh"等。正確設置lang屬性可以提高網頁的可訪問性和搜索引擎排名。

HTML屬性的目的是什麼?HTML屬性的目的是什麼?May 07, 2025 am 12:01 AM

htmlattributeseresene forenhancingwebelements'functionalityandAppearance.TheyAdDinformationTodeFineBehavior,外觀和互動,使網站互動,響應式,visalalyAppealing.AttributesLikutesLikeSlikEslikesrc,href,href,href,類,類型,類型,和dissabledtransfransformformformformformformformformformformformformformformforment

您如何在HTML中創建列表?您如何在HTML中創建列表?May 06, 2025 am 12:01 AM

toCreateAlistInHtml,useforforunordedlistsandfororderedlists:1)forunorderedlists,wrapitemsinanduseforeachItem,RenderingeringAsabulletedList.2)fororderedlists,useandfornumberedlists,useandfornumberedlists,casundfornumberedlists,casundfornthetthetthetthetthetthetthetttributefordforderfordforderforderentnumberingsnumberingsnumberingStys。

HTML行動:網站結構的示例HTML行動:網站結構的示例May 05, 2025 am 12:03 AM

HTML用於構建結構清晰的網站。 1)使用標籤如、、定義網站結構。 2)示例展示了博客和電商網站的結構。 3)避免常見錯誤如標籤嵌套不正確。 4)優化性能通過減少HTTP請求和使用語義化標籤。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境