Iframe
нельзя изменить в Firefox. Затем я решил поместить его в div
и изменить его размер:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Resizable Iframe & Textarea</title>
<style>
#top, #bottom {
width:300px;
height:200px;
border:1px solid #ccc;
padding:10px;
}
#top {
overflow:auto;
resize:vertical;
}
iframe, textarea {
display:block;
width:100%;
height:100%;
margin:0;
border:0;
padding:0;
resize:none;
background:#ccc;
}
</style>
</head>
<body>
<div id="parent">
<div id="top">
<iframe name="myFrame" src="about:blank"></iframe>
</div>
<div id="bottom">
<textarea></textarea>
</div>
</div>
<script>
var parent = document.getElementById("parent").style.height;
var top = document.getElementById("top").style.height;
var bottom = document.getElementById("bottom").style.height;
window.frames["myFrame"].onresize = function() {
bottom = parent - top;
}
</script>
</body>
</html>
Демонстрация: http://jsfiddle.net/RainLover/EY4mR/
Вот что Я хотел бы добиться: когда я увеличиваю верхний div
, нижний div
должен уменьшаться (и наоборот), поэтому размер родительского div
остается фиксированным.
Примечание. Пожалуйста, не подключайте frameset
или jQuery! Все, что мне нужно, это простой подход JavaScript для расчета и изменения высоты нижнего div
, как только я изменяю размер верхнего div
.
Спасибо!
Обновление: свойство изменения размера в CSS3 плохо поддерживается: IE11 вообще его не понимает, а в Chrome/Safari/Opera вы можете только увеличить элемент, не уменьшайте его размер. Поэтому я решил изменить свой подход и вместо ручки изменения размера пользовательского интерфейса использовать ползунок. Интересно, не могли бы вы просмотреть мой код и сообщить мне, что вы думаете:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Resize</title>
<style>
textarea,
iframe {
display: block;
width: 300px;
height: 200px;
margin: 0;
border: 0;
padding: 0;
}
textarea {
background: green;
resize: none;
}
iframe {
background: blue;
}
</style>
</head>
<body>
<input id="slide" oninput="resize();" type="range" min="0" max="400" value="200">
<textarea id="textarea"></textarea>
<iframe id="iframe"></iframe>
<script>
var slide = document.getElementById("slide");
var textarea = document.getElementById("textarea");
var iframe = document.getElementById("iframe");
function resize() {
var slideValue = slide.value;
textarea.style.height = slideValue + "px";
iframe.style.height = 400 - slideValue + "px";
}
</script>
</body>
</html>
Демонстрация: http://jsfiddle.net/RainLover/EY4mR/24/