放大和缩小后输入下降

时间:2018-05-28 14:10:41

标签: html css html5 input

这里我创建了两个简单的输入字段,但是当我放大并缩小页面(Ctrl +鼠标滚轮)时,输入字段会以某种方式改变位置,输入会向下和向上移动,为什么会这样做?无论我放大还是放大,如何将它们放在同一个地方?

body {
  width: 870px;
}

#col3 {
  width: 400px;
  float: left;
  /*background-color:#383838;*/
  margin: 20px 10px 10px 30px;
}

form {
  width: 380px;
  margin: auto;
  padding: 5px;
  border: solid 1px white;
}

fieldset {
  margin: auto;
  border: solid 1px #E37222;
  padding-left: 19px;
  padding-top: 15px;
  background-color: #EEEEDD;
}

label {
  display: block;
  width: 70px;
  float: left;
  margin-left: 10px;
}

span {
  margin-left: -16px;
}

legend {
  background-color: #E37222;
  color: white;
}

input.tt {
  outline: 1px solid #909090;
}

.tt {
  margin-top: 8px;
}
<div id="col3">
  <form>
    <fieldset>
      <legend>eeeee</legend>

      <label for="name">
        <span>rrr:</span>
      </label>
      <input class="tt" type="text" size="34" />
      <br />

      <label class="tt" for="email">
        <span>ttt:</span>
      </label>
      <input class="tt" type="text" size="34" />

    </fieldset>
  </form>
</div>

..........................

3 个答案:

答案 0 :(得分:2)

删除float:left

<label>
label{
    display:block;
    width:70px;
    margin-left:10px;

}

答案 1 :(得分:1)

要么稍微改变你的标记,要么使用flexbox / grid。

<style>

body{
width:870px;

}
#col3{
	width:400px;
	float:left;
	/*background-color:#383838;*/
	margin:20px 10px 10px 30px;

}
form{
	width:380px;
	margin:auto;
	padding:5px;
	border:solid 1px white;
}
fieldset{
	margin:auto;
	border:solid 1px #E37222;
	padding-left: 19px;
    padding-top: 15px;
	background-color:   #EEEEDD;
}

label{
	display:block;
    width: 100%;
}

label div{
    padding-right: 5px;
    width: 68px;
    display: inline-block;
}

legend{
background-color:#E37222;
color:white;
}


input.tt{
    outline: 1px solid #909090;
}
.tt{
    margin-top:8px;
}

</style>
</head>
<body>

<div id="col3">
	<form ">
	<fieldset >
			<legend>eeeee</legend>

			<label  for="name"><div>rrr:</div><input class="tt type="text" size="34" /> </label>
			
			<br/>		

			<label class="tt"for="email"><div>ttt:</div><input class="tt" type="text" size="34" /></label>
			
	
		
			
			
		
		</fieldset>
	</form>
	</div>
	
	
	
</body>
   

答案 2 :(得分:1)

尝试使用此

.youclassname{
 display:flex;
}

<div class="yourclassname">
  <label  for="name"><span>rrrrrr rrrrrr:</span></label>
  <input class="tt type="text" size="34" /> 
</div>