- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 playframework 2.3.8,我正在尝试实现某种类似 Stack Overflow 的投票系统。到目前为止,我在 map 上有一些问题/答案,我将其发送到 View 。按钮在那里,但我不知道如何让它们对点击使用react以更改评分(arrowUp 应该对计数器进行投票,arrowDown 类似)。
这是一个示例图片:
这是我的 Controller Application.java:
static Map<Question, List<Answer>> myMap = new HashMap<Question, List<Answer>>();
public static void initialize() {
// Question format: ID / questionText / voteScore / userID
// Answer format: ID / questionID (answer linked to question) / answerText / voteScore / userID
Question question1 = new Question("xyz", "Do Androids dream?", 127, "Marcus");
Answer answer11 = new Answer("zab", "xyz", "Only of electric sheep!", 70, "Tibor");
Answer answer12 = new Answer("qwert", "xyz", "No, they dont!", 10, "Sarah");
List<Answer> answerList1 = new ArrayList<Answer>();
answerList1.add(answer11);
answerList1.add(answer12);
myMap.clear();
myMap.put(question1, answerList1);
}
public static Result index() {
initialize();
return ok(views.html.index.render(myMap));
}
这是我的 View 类 (index.scala.html):
@import model.Question
@import model.Answer
@(myMap: Map[Question, List[Answer]])
@main("Main") {
@for((question, value) <- myMap){
(some HTML to make it look nice)
<button type="button" class="btn btn-default" onclick="voteUp()" id="upvoteButton"
value="voteUp" style="width: 30px; height: 30px; text-align: center; vertical-align: center;">
<span class="glyphicon glyphicon-arrow-up" aria-hidden="true" style="color:orange"></span>
</button>
@question.voteScore
(some HTML to make it look even nicer)
}
我的routes.conf:
GET / controllers.Application.index()
GET / controllers.Application.upVote()
GET /Forum controllers.Forum.askQuestion()
GET /Einstellungen controllers.Application.showSettings()
GET /Quiz controllers.Application.startQuiz()
我不知道是否可以通过 Controller 类在路由上使用按钮,因为大多数其他项目似乎都使用 Javascript。那么如何捕获按钮点击并更新 voteScore 呢?
[EDIT1]:我现在添加了一个脚本,仅增加第一个问题的 voteScore。
<script language="javascript">
function voteUp() {
var num = $('#num');
var currentNumber = num.text().length ? parseInt(num.text()) : 0;
num.text(currentNumber + 1);
}
</script>
在我的index.scala.html中,我向@question.voteScore添加了一个span标签:
<span id="num"> @question.voteScore </span>
但是当我迭代 map 时,我只能更改第一个问题的值。第一个赞成按钮有效,而所有其他按钮也会增加第一个问题的投票分数!
那么如何从 map 中获取每个相应问题的相应值,更改它并将其放回 map 中?
最佳答案
首先您需要做的是捕获该按钮上的点击事件。使用 jquery,使用类或 id 将事件监听器添加到特定按钮。
第二您需要在事件监听器内进行 AJAX 调用,这将调用 API,并且 onSuccess 使用 jquery 函数在 UI 中进行增量,以防出现错误,显示从 API 收到的错误消息。
第三 在Play中创建一个API,无论你想要什么,这个API都会在AJAX中从UI调用。您需要创建不同的 API 来对问题和答案进行投票。在这两个 API 中,都将 id 作为参数并递增 DB 中的值,然后返回递增的值。如果有任何错误或参数错误,请发送状态码 > 300 的错误消息。
关于java - 如何对按钮单击使用react以更改 map 中的参数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30007280/
所以我有这个 javascript 片段,它有两个按钮可以进入全屏,一个按钮可以退出全屏。我想做到这一点,如果我不在全屏模式下,按钮会显示转到全屏模式,而当我处于全屏模式时,按钮会显示退出全屏模式..
我在自定义控件中添加了一个新属性作为可扩展属性,例如属性网格中的字体属性。在 Windows 窗体应用程序项目中使用我的自定义控件后,我在属性网格中看到一个省略号 (…) 按钮,如字体属性的“…”按钮
我在自定义控件中添加了一个新属性作为可扩展属性,例如属性网格中的字体属性。在 Windows 窗体应用程序项目中使用我的自定义控件后,我在属性网格中看到一个省略号 (…) 按钮,如字体属性的“…”按钮
我尝试将 Twitter 上的“Tweet Me”按钮 ( http://twitter.com/goodies/tweetbutton ) 添加到我的网站。然而,每当按下按钮时,我都会收到此 Jav
我试图在我的文本区域中获取一个按钮值,如果我使用 则工作正常但如果我使用那么它就不起作用了。你能找出问题所在吗? HTML 1 2 3 4 JavaScript $(document).read
我的 C# Winform 面板中有一堆文本框。每行文本框的命名如下: tb1 tbNickName1 comboBox1 tb2 tbNickName2 comboBox2 tb3 tbNickNa
我有一个表单,其中过滤器下方有按钮(应用过滤器和清除过滤器),我试图在单击“应用”按钮时显示“清除”,并在单击“清除”按钮时隐藏“清除”按钮。 下面的代码(如果我的表有的话):
excel 按钮正在工作,但是当我添加 pdf 按钮时,它添加仅显示 pdf 按钮 excel 按钮在 pdf 按钮添加后隐藏 $(document).ready(function() { $
我想创建一个 div 作为标题并分成 3 列,并按以下顺序在其中放置 2 个按钮和一个标题:Button1(左位) Title(居中) Button2(右位) 这是我为这个 div 编写的代码:
仅当选中所有框时才应禁用“允许”按钮。我该怎么做?我已经完成了 HTML 部分,如下所示。如何执行其中的逻辑部分?即使未选中一个复选框,也应禁用“允许”按钮
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
如您所知,您可以使用 2 种方法在 HTML5 中呈现按钮: 使用 void 元素 或 如果您需要内容,请使用 元素(不是空元素)。 在JSF2中,有2种方式生成按钮;与UICommand或 UIOu
我尝试根据表单元素的更改禁用/启用保存按钮。但是,当通过弹出按钮选择更改隐藏输入字段值时,保存按钮不受影响。 下面是我的代码。我正在尝试序列化旧的表单值并与更改后的表单值进行比较。但我猜隐藏的字段值无
我有用于在消息(电子邮件、短信)上输入内容的 EditText。我希望在单击 ActionDone 按钮时立即发布消息。我为此使用以下代码: message.setOnEditorActionList
我的 Android 应用程序中有一堆 EditText,每个都将 InputMethod 设置为 numberSigned。我的目标设备没有硬件键盘,而是使用软件键盘输入数字。 Android 将输
我无法以编程方式隐藏弧形菜单中的 fab 按钮。我正在使用https://github.com/saurabharora90/MaterialArcMenu在我的代码中。如何在Java中以编程方式隐藏
我已经看到这在其他类型的对话框窗口中是可能的,例如“showConfirmDialog”,其中可以指定按钮的数量及其名称;但是使用“showInputDialog”时是否可以实现相同的功能?我似乎无法
相同的按钮用于激活和停用。第一次,当代码运行按钮单击并成功“停用”时。但第二次,代码无法找到该元素。第一个案例按钮位于第二个“a”标签中,然后停用第一个“a”标签中的按钮。 案例1: Edit
是否可以将按钮的 onclick 操作设置为 JavaScript 变量?这个想法是我们用 JavaScript 控制一个表。每当点击该表的一行时,我们就会更新一个 JavaScript 变量。该 v
我想创建一个按钮,它包含左侧的文本和右侧的复选框(或任何其他组件)。我怎样才能做到这一点? 我发现我可以制作自己的 View extends Button,但是如果可以的话我应该如何实现 onDraw
我是一名优秀的程序员,十分优秀!