我正在构建一个小的上传元素。
这是一个div(实际上是vue /类星体卡,但我想这并不重要),它会根据窗口的大小和视口而做出响应,并且会不断增长和缩小。
它包含一个包含输入和另一个div的表单
问题:
输入应透明,仅提供功能。我希望另一个div恰好位于其下并显示图标和文本。输入和内部div都应完全填充封闭元素
到目前为止我已经尝试过:
设置
positions: absolute
和relative
,使用z-index
。
当位置相对时,将宽度和高度设置为100%起作用,但是元素彼此相邻。当使用绝对位置时,覆盖层可以工作,但是输入元素变得比其父元素大得多。
我无法直接设置其大小。
<div style="width: 500px; height: 400px; background-color: #990000"> <!-- actually a card from the vue / quasar framework -->
<form enctype="multipart/form-data" method="post" style="height: 100%">
<div class="justify-center column" style="height:100%">
<input type="file" multiple :name="uploadFieldName" :disabled="isSaving" @change="filesChange()" style="align-content: center; opacity: 0.5; /* invisible but it's there! */
background-color: yellow;
width: 100%;
height: 100%;">
<div class="justify-center column" style="height: 100%; background-color: #009900;">
<q-icon name="add" size="40px" color="secondary" class="q-pa-md" />
<p class="text-secondary no-padding no-margin" style="font-size: 12px">drop documents here</p>
</div>
</div>
</form>
</div>
https://codepen.io/anon/pen/ywNVYB
预先感谢
答案 0 :(得分:1)
如果我正确理解了您的问题-那么您应该为输入创建标签,隐藏输入并按所需方式设置标签样式。连接标签并通过ID和输入,然后单击标签即可上传文件
这是一个例子
[type=file] {
position: absolute;
width: 100%;
height: 100%;
opacity: 0;
top: 0;
}
label {
background-color: gold;
width: 250px;
height: 50px;
border-radius: 8px;
display: block;
position: relative;
}
label span {
display: flex;
width: 100%;
height: 100%;
align-items: center;
justify-content: center;
}
[type=file]:hover {
cursor: pointer;
}
<label for='input1'>
<span>click me or drag your files here</span>
<input id='input1' type='file'>
</label>