ホームページ > 記事 > ウェブフロントエンド > jsによるrem自動マッチングとフォントサイズ計算の実装を説明する例
実際の開発プロセスでは、さまざまな幅と高さの計算に戸惑うことがよくあります。特に rem 計算方法を使用する場合、アダプティブ レイアウトは多くのプログラマを悩ませます。このような問題を解決するには、jsを使って画面幅の変化を監視し、HTMLのルート要素であるfont-sizeの値を変更すれば良いと思います。この記事では主にjsでの自動remマッチングとfont-sizeの計算の例を紹介しますが、編集者が非常に良いと思ったので、参考として共有します。編集者をフォローして見てみましょう。皆さんのお役に立てれば幸いです。
以下は、関連する JavaScript 実装コードです:
(function (doc, win) { var docEl = doc.documentElement, resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize', recalc = function () { var clientWidth = docEl.clientWidth; if (!clientWidth) return; if(clientWidth>=640){ docEl.style.fontSize = '100px'; }else{ docEl.style.fontSize = 100 * (clientWidth / 640) + 'px'; } }; if (!doc.addEventListener) return; win.addEventListener(resizeEvt, recalc, false); doc.addEventListener('DOMContentLoaded', recalc, false); })(document, window);
このコードは、基本値として 640 ピクセルを選択します。なぜ 640 ピクセルを選択するのでしょうか?
ピクセルが存在しないことを保証するため、ページ幅 640 ピクセルが安全な最大幅です。モバイルページの両側 空白のままにします。ここでの px は CSS 論理ピクセルであり、デバイスの物理ピクセルとは異なることに注意してください。たとえば、iPhone 5 は Retina スクリーンを使用し、2px x 2px のデバイス ピクセルを使用して 1px x 1px の CSS ピクセルを表すため、デバイスのピクセル番号は 640 x 1136px、CSS 論理ピクセル番号は 320 x 568px になります。 。
そのため、モバイル ページに切り替える場合は、レンダリングの幅を 640 ピクセルにスケールする必要があります。
たとえば、ページ上の p の幅が 60、高さが 65 の場合、次のようにスタイルを直接記述することができます:
{ width:0.6rem; height:0.65rem }
ブラウザ互換性
rem は CSS3 A で新しく導入されました測定単位を変更すると、誰もがブラウザのサポートについて不満や不安を感じることになるでしょう。実際、Mozilla Firefox 3.6 以降、Apple Safari 5 以降、Google Chrome、IE9 以降、Opera11 以降など、サポートされているブラウザが多数あることに驚かれるかもしれません。貧弱な IE6 ~ 8 ではそれができないので、それらを透明なものとして扱ってください。私はいつもそうしています。
ただし、単位を使用してフォントを設定する場合、IE を完全に無視することはできません。この REM を使用したいが、IE での効果と互換性を持たせたい場合は、「px」と「rem」を併用することを検討できます。 IE6~8で効果を実現するには「px」を使用し、ブラウザの効果を実現するには「Rem」を使用します。テキストの変更によって IE6 ~ 8 が変更されないようにしてください。誰がこの Ie6 ~ 8 をこんなに古いものにしたのでしょうか。試してみたくなければ、これは非常に興味深い測定単位になるかもしれません。
完全なコード例:
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <meta content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0;" name="viewport" /> <meta content="telephone=no" name="format-detection" /> <meta name="format-detection" content="email=no" /> <meta http-equiv="Cache-Control" content="no-cache"/> <title>响应式布局</title> <style> html{font-size: 20px;width: 100%;height: 100%;} body{margin: 0;padding: 0;} header,footer{width: 100%;background: #17A578;color: #fff;font-size:1rem;text-align: center;line-height: 2rem;} .footer{position: fixed;bottom: 0;} .box{} .public{width: 5rem;height: 5rem;font-size: 1.2rem;display: inline-block;text-align: center;color: #fff;line-height: 5rem;margin-top: 1rem;} .left{background: #f00;} .center{background: #048F74;} .right{background: #000;} </style> </head> <body> <header>页面头部</header> <p class="box"> <p class="public left">左</p> <p class="public center">中</p> <p class="public right">右</p> <p class="public left">左</p> <p class="public center">中</p> <p class="public right">右</p> </p> <footer class="footer">页面底部</footer> <script> //orientationchange方向改变事件 (function (doc, win) { var docEl = doc.documentElement,//根元素html //判断窗口有没有orientationchange这个方法,有就赋值给一个变量,没有就返回resize方法。 resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize', recalc = function () { var clientWidth = docEl.clientWidth; if (!clientWidth) return; //把document的fontSize大小设置成跟窗口成一定比例的大小,从而实现响应式效果。 docEl.style.fontSize = 20 * (clientWidth / 320) + 'px'; }; //alert(docEl) if (!doc.addEventListener) return; win.addEventListener(resizeEvt, recalc, false);//addEventListener事件方法接受三个参数:第一个是事件名称比如点击事件onclick,第二个是要执行的函数,第三个是布尔值 doc.addEventListener('DOMContentLoaded', recalc, false)//绑定浏览器缩放与加载时间 })(document, window); //alert(document.documentElement.clientWidth/320) </script> </body> </html>
関連する推奨事項:
フォントサイズ構文の概要と関連するサンプルチュートリアルを共有します
Web ページを改善するための CSS の font-size-adjust 属性の使用方法の詳細な紹介レイアウト
wap モバイル ページは、dpr と width_html/css_WEB-ITnose に基づいて font-size の対応する値を計算します
以上がjsによるrem自動マッチングとフォントサイズ計算の実装を説明する例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。