使用变换比例将div放在div的中间

时间:2016-05-06 04:34:57

标签: javascript html css css3

我正在尝试将div放在另一个div的中间(水平和垂直)并将其缩放到最大值,同时保持纵横比。

如果我进行缩放但它保持在顶部/左侧,但是一旦我试图将它居中,它就会很好地运行。

#area是一个外部div,#cont是要缩放的主要内容div。 IRL它内部有一个复杂的结构,而不仅仅是一个图像,如下例所示。

有一些jsfiddle例子显示了我的尝试。要查看我的意思,请调整结果iframe的大小。

这是将div保持在左/上的缩放: https://jsfiddle.net/regc/3t4n3xud/1/

CSS

#area {
    top: 40px;
    bottom: 40px;
    left: 10px;
    right: 10px;
    display: block;
    position: absolute;
    border: 4px solid #73AD21;
}
#cont {
    width: 500px;
    height: 200px;
    position: absolute;
    border: 4px solid #aa2221;
}

JS:

cont_el.style['transform'] = 'scale(' + scale + ')';

cont_el.style['transform-origin'] = 'left top';

cont_el.style.width = i.width * scale;
cont_el.style.height = i.height * scale;

以下是我尝试将其置于中心位置但它会破坏: https://jsfiddle.net/regc/4gcxcn7j/11/

CSS

#area {
    top: 40px;
    bottom: 40px;
    left: 10px;
    right: 10px;
    display: block;
    position: absolute;
    border: 4px solid #73AD21;
}
#cont {
    width: 500px;
    height: 200px;
    position: absolute;
    border: 4px solid #aa2221;
    margin:  0 auto;
    top: 50%;
    transform: translateY(-50%);
}

JS

cont_el.style['transform'] = 'scale(' + scale + ') translateY(-50%)';

cont_el.style['transform-origin'] = 'center center';

cont_el.style.width = i.width * scale;
cont_el.style.height = i.height * scale;

cont_el.style.margin = '0 auto';

cont_el.style.top = '50%';

1 个答案:

答案 0 :(得分:2)

我希望这就是你想要的!!使用transform-origin:top left;

<强> FIDDLE

&#13;
&#13;
scale_cont()
window.addEventListener('resize', scale_cont)

function scale_cont() {
  const o = getComputedStyle(document.getElementById('area'))
  const i = getComputedStyle(document.getElementById('cont'))

  const cont_el = document.getElementById('cont')

  const scale = Math.min(
    parseFloat(o.width) / parseFloat(i.width),
    parseFloat(o.height) / parseFloat(i.height));
  console.log('scale ', scale)

  /*
  	cont_el.style['-webkit-transform'] = 'scale(' + scale + ')';
  	cont_el.style['-moz-transform'] = 'scale(' + scale + ')';
  	cont_el.style['-o-transform'] = 'scale(' + scale + ')';
  	cont_el.style.transform = 'scale(' + scale + ')';
  */

  cont_el.style.transform = 'scale(' + scale + ') translate(-50%, -50%)';
  cont_el.style['-o-transform'] = 'scale(' + scale + ') translate(-50%, -50%)';
  cont_el.style['-webkit-transform'] = 'scale(' + scale + ') translate(-50%, -50%)';
  cont_el.style['-moz-transform'] = 'scale(' + scale + ') translateY(-50%, -50%)';


  cont_el.style['-webkit-transform-origin'] = 'top left';
  cont_el.style['-moz-transform-origin'] = 'top left';
  cont_el.style['-o-transform-origin'] = 'top left';
  cont_el.style['transform-origin'] = 'top left';

  cont_el.style.width = i.width * scale;
  cont_el.style.height = i.height * scale;



  cont_el.style.margin = '0 auto';

  cont_el.style.top = '50%';

  // cont_el.style.transform = 'translateY(-50%)';

}
&#13;
#area {
  top: 40px;
  bottom: 40px;
  left: 10px;
  right: 10px;
  display: block;
  position: absolute;
  border: 4px solid #73AD21;
}
#cont {
  width: 500px;
  height: 200px;
  position: absolute;
  border: 4px solid #aa2221;
  margin: 0 auto;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transform-origin: top left;
}
#cont img {
  width: 100%;
  height: 100%;
  max-width: 100%:
}
#all,
#main {
  height: 100%;
  width: 100%;
  margin: 0;
  padding: 0;
  top: 0;
  left: 0;
  position: absolute;
  display: block;
  overflow: none;
  box-sizing: inherit;
}
#header {
  width: 100%;
  height: 30px;
  position: relative;
  top: 0;
  left: 0;
  background: #a4f4f4;
}
#footer {
  width: 100%;
  height: 30px;
  position: fixed;
  bottom: 0;
  left: 0;
  background: #34f4f4;
}
&#13;
<div id='all'>
  <div id='main'>
    <div id='header'>
      Header
    </div>
    <div id='area'>
      <div id='cont'>
        <img src='https://www.google.com.au/images/branding/googlelogo/2x/googlelogo_color_272x92dp.png' />
      </div>
    </div>
    <div id='footer'>
      Footer
    </div>
  </div>
</div>
&#13;
&#13;
&#13;