ホームページ >ウェブフロントエンド >jsチュートリアル >JS での画像の伸縮と適応を防ぐ方法

JS での画像の伸縮と適応を防ぐ方法

php中世界最好的语言
php中世界最好的语言オリジナル
2018-04-13 14:11:462286ブラウズ

今回は、JS で画像の伸縮や適応を防ぐ方法と、JS で画像の伸縮や適応を防ぐための 注意事項 について説明します。実際のケースを見てみましょう。

はじめに

フロントエンドとして日常の Web 開発を行っていると、画像の引き伸ばしに関する問題に遭遇することがよくあると思います。

たとえば、バナー、画像とテキストのリスト、アバターなどはすべて、ユーザーまたは顧客が独自に画像を操作してアップロードできる場所であり、画像が関与すると、当然ながら手動でトリミングが行われます。写真のアップロードにより、ユーザーまたは顧客は、写真の効果的なコンテンツが最適なソリューションであることを明確に認識しています。ただし、さまざまな外部要因の下で、トリミングがない場合は、それに合わせてフロントエンド ディスプレイで処理する必要があります。あらゆるサイズの写真をアップロードする場合、最適な表示効果が必要です。

写真をフレームに入れるには何ステップ必要ですか? 3 つのステップ...始めましょう

ステップ 1: 最初にフレームを描画します (これはアダプティブ フレームの方法です)

// 假定需要一个在750px屏幕下宽400px,高280px的盒子
// 宽度 = 400 / 750 = 0.5333
// 高度 = 280 / 400 * 0.5333 = 0.3733
<style>
 .img-box{
  position: relative;
  width: 53.33%;
  height: 0;
  padding-bottom: 37.33%;
  overflow: hidden;
  background-color: #eee;
 }
</style>
<body>
 <p id="list">
  <p class="img-box">
   <img src="..."/>
  </p>
 </p>
</body>

ステップ 2: 画像に必要な CSS を設定します

<style>
 .width{
  position: absolute !important;
  width: 100% !important;
  min-height: 100% !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  -ms-transform: translateY(-50%) !important;
  -moz-transform: translateY(-50%) !important;
  -webkit-transform: translateY(-50%) !important;
  -o-transform: translateY(-50%) !important;
  display: block;
 }
 .height{
  position: absolute !important;
  height: 100% !important;
  min-width: 100% !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  -ms-transform: translateX(-50%) !important;
  -moz-transform: translateX(-50%) !important;
  -webkit-transform: translateX(-50%) !important;
  -o-transform: translateX(-50%) !important;
  display: block;
 }
</style>

ステップ 3: js は画像の高さの比較を取得し、クラス名を img に追加します

//需要注意的是,不能在css中直接给img设置宽度和高度
//否则在img.onload后获取的宽高是css设置的宽高
//同时建议使用dom对象来获取img标签
<script>
 var list = document.getElementById('list');
 getImgWH ( list );
 //执行宽高比对并设置img类名
 function getImgWH ( Obj ) {
  var img = Obj.getElementsByTagName('img');
  for( var i=0 ; i<img.length ; i++ ){
   img[i].onload = function(){
    var width = this.width;
    var height = this.height;
    if ( width > height ) {
     this.classList.add('height');
    } else if ( width < height ) {
     this.classList.add(&#39;width&#39;);
    } else {
     this.style.width = &#39;100%&#39;;
     this.style.height = &#39;100%&#39;;
    }
   }
  }
 }
</script>

画像が引き伸ばされないようにするのは比較的簡単ですが、実際のプロジェクトでは十分な注意が必要です。Web ページは画像または画像になり、引き伸ばされた画像はデザイナーがそれを気にするのを待つだけです。ははは...

この記事の事例を読んだ後、あなたはその方法を習得したと思います。さらに興味深い情報については、php 中国語 Web サイトの他の関連記事に注目してください。

推奨読書:

Jstree が親ノードを選択すると、子ノードの無効化も選択されます

Swiper でカスタム ページャーを使用する手順の詳細な説明

以上がJS での画像の伸縮と適応を防ぐ方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。