- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图通过在我的脚本中的放置区域“下面”添加一些文本形式的提示来帮助我的用户做出选择。这会导致可拖动按钮锁定在文本下方,看起来很丑陋。
在我这里的示例中,可拖动按钮适合“方框 3”,但我该怎么做才能使它以相同的方式(并隐藏提示)适合“方框 2”?
并且,假设按钮具有不同的值(即数字)。我将如何编写一个脚本来添加这些值并在“摘要”中打印出来?
值不存在于按钮内的文本中。老实说——我真的不知道把这些值放在哪里。我想我可以做一个“大量的”if-else 并在 innerHTML 等于 bla bla 时添加某个值 - 但这看起来很幼稚...
拜托,只有 Vanilla - 我正在努力学习这一点。
var dropTarget = document.querySelectorAll(".wrapper");
var draggables = document.querySelectorAll(".button");
// Legger til en eventlistener på alle knappene
for (let i = 0; i < draggables.length; i++) {
draggables[i].addEventListener("dragstart", function(ev) {
ev.dataTransfer.setData("srcID", ev.target.id);
});
}
for (let i = 0; i < dropTarget.length; i++) {
dropTarget[i].addEventListener("dragover", function(ev) {
ev.preventDefault();
});
dropTarget[i].addEventListener("drop", function(ev) {
ev.preventDefault();
let target = ev.target;
let srcID = ev.dataTransfer.getData("srcID");
let droppable = target.classList.contains("wrapper");
if (droppable) {
target.appendChild(document.getElementById(srcID));
}
});
}
.bord-box {
margin: 0px;
height: 100px;
width: 100px;
padding: 5px;
border: solid 1px grey;
border-radius: 5px;
}
.box1 {
margin: 0px;
height: 100px;
width: 100px;
padding: 5px;
border: solid 1px grey;
}
.box2 {
margin: 0px;
height: 100px;
width: 100px;
padding: 5px;
border: solid 1px red;
}
.button {
margin: 5px 0 5px 0;
border: solid 1px grey;
height: 30px;
width: 90px;
}
.mottak {
height: 40px;
background-color: grey;
}
<div class="section">
<div class="column" style="position:absolute; top:50px;">
<p>Box 1</p>
<div class="bord-box wrapper">
<button id="value1" class="button" draggable="true">Text 1</button>
<button id="value2" class="button" draggable="true">Text 2</button>
</div>
</div>
<div class="column" style="position:absolute; left:200px; top:50px;">
<p>Box 2</p>
<div class="box1">
<div class="mottak wrapper">
Move button here ...
</div>
</div>
</div>
<div class="column" style="position:absolute; left:400px; top:50px;">
<p>Box 3</p>
<div class="box2">
<div class="mottak wrapper">
</div>
</div>
</div>
<div class="column" style="position:absolute; left:600px; top:50px;">
<p>Summary</p>
<div class="box1">
<p>Sum value of buttons Text 1 and Text 2</p>
</div>
</div>
最佳答案
这是一个简单的快速修复方法,只需将伪类添加到 .mottak
元素即可。但是,请注意,:empty
的元素中不能有任何空格。
.mottak:empty::before
基本上只在该元素为空(没有子元素)时添加 content
属性
var dropTarget = document.querySelectorAll(".wrapper");
var draggables = document.querySelectorAll(".button");
// Legger til en eventlistener på alle knappene
for (let i = 0; i < draggables.length; i++) {
draggables[i].addEventListener("dragstart", function(ev) {
ev.dataTransfer.setData("srcID", ev.target.id);
});
}
for (let i = 0; i < dropTarget.length; i++) {
dropTarget[i].addEventListener("dragover", function(ev) {
ev.preventDefault();
});
dropTarget[i].addEventListener("drop", function(ev) {
ev.preventDefault();
let target = ev.target;
let srcID = ev.dataTransfer.getData("srcID");
let droppable = target.classList.contains("wrapper");
if (droppable) {
target.appendChild(document.getElementById(srcID));
}
});
}
/** added */
.mottak:empty::before {
content: "Move button here...";
}
/* end of edit */
.bord-box {
margin: 0px;
height: 100px;
width: 100px;
padding: 5px;
border: solid 1px grey;
border-radius: 5px;
}
.box1 {
margin: 0px;
height: 100px;
width: 100px;
padding: 5px;
border: solid 1px grey;
}
.box2 {
margin: 0px;
height: 100px;
width: 100px;
padding: 5px;
border: solid 1px red;
}
.button {
margin: 5px 0 5px 0;
border: solid 1px grey;
height: 30px;
width: 90px;
}
.mottak {
height: 40px;
background-color: grey;
}
<div class="section">
<div class="column" style="position:absolute; top:50px;">
<p>Box 1</p>
<div class="bord-box wrapper">
<button id="value1" class="button" draggable="true">Text 1</button>
<button id="value2" class="button" draggable="true">Text 2</button>
</div>
</div>
<div class="column" style="position:absolute; left:200px; top:50px;">
<p>Box 2</p>
<div class="box1">
<div class="mottak wrapper"></div>
</div>
</div>
<div class="column" style="position:absolute; left:400px; top:50px;">
<p>Box 3</p>
<div class="box2">
<div class="mottak wrapper"></div>
</div>
</div>
<div class="column" style="position:absolute; left:600px; top:50px;">
<p>Summary</p>
<div class="box1">
<p>Sum value of buttons Text 1 and Text 2</p>
</div>
</div>
关于javascript - 将文本放在拖放区域下方,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54717081/
我当前项目中的许多类都有几个只能从类本身内部调用的属性和方法。此外,根据类(class)的当前状态,它们可能会扰乱类(class)的工作。 目前,所有这些接口(interface)都在 .h 文件的主
我想使用ngbTabSet将nav-pills in card-header 和tab-content in card-body。但我不知道该怎么做。 这是我尝试实现的示例(使用 bootstrap.
我正在浏览文档以查找如何允许放置在停靠栏图标上。据我所知,建议您使用 LSItemContentTypes,因为 CFBundleTypeOSTypes 已弃用。但是,我无法让 LSItemConte
我正在尝试在书签中使用 jquery UI 作为 slider 。并且 jquery ui 要求在普通 jquery 文件之后包含该文件。 所以到目前为止我所尝试的只是将脚本附加到 header ,同
您好,我尝试了广泛的谷歌搜索,但似乎没有任何帮助。 这是我的场景: 公司 Logo 存储在外部域/网址(矩形)中。 带有谷歌地图的 Ionic 应用程序,将这些 Logo 作为标记放置在 map 上。
我今天在阅读我的一些 C# 代码时发现了这一行: if (ProgenyList.ItemContainerGenerator.Status != System.Windows.Controls.Pr
我刚遇到this question在 Go FAQ 中,它让我想起了困扰我一段时间的事情。不幸的是,我真的不明白答案是什么。 似乎几乎所有非 C 类语言都将类型放在变量名之后,如下所示: var :
这是有效的 HTML 吗? 最佳答案 作为元素可以包含 phrasing content ,以及属于该组,则有效。 从语义上(并且具有一些常识),如果唯一的内容是 , 不;如果它同时包含文本和图像
这是有效的 HTML 吗? 最佳答案 作为元素可以包含 phrasing content ,以及属于该组,则有效。 从语义上(并且具有一些常识),如果唯一的内容是 , 不;如果它同时包含文本和图像
我有两本 T.Parr 写的关于 ANTLR 的书,我到处都看到美元符号和符号的引用。它也对我有用: term : IDENT -> { new TokenNode($IDENT) }; 或更复杂的东
我在实现段控制时遇到了一些问题。因为我希望它是一个固定的标题,所以当我滚动时我总是可以看到它,我已经在 - (UIView *)tableView:(UITableView *)tableView v
我有一个 20x36px (10x18pt) 的箭头图像,当我选择一个 UIImageView 时,将它拖到我的 View Controller 上然后设置图像,它总是模糊的。我只在我的项目中包含 @
How can I put background image when I hover a link Insert Bg in this a when hov
我需要在我的 .container 中添加(最新的第一个)新分区,但在 .controls (按钮)之后。可能吗? 注意:添加新的分区来保存按钮下方的前置控件对我来说不是一个选择。 HTML 需要保持
我是一名优秀的程序员,十分优秀!