Iframe
ไม่สามารถreziable ใน 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 คุณสามารถขยายได้เฉพาะองค์ประกอบเท่านั้น ไม่ปรับขนาดให้เล็กลง ดังนั้นฉันจึงตัดสินใจเปลี่ยนวิธีการของฉันและแทนที่จะใช้ตัวจัดการปรับขนาด UI ให้ใช้ตัวควบคุมแถบเลื่อน ฉันสงสัยว่าคุณสามารถตรวจสอบรหัสของฉันและแจ้งให้เราทราบว่าคุณคิดอย่างไร:
<!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>