0

以下是字段描述中包含的内容,因此我可以显示摘要行。

  <script type="text/javascript">
   var table = AJS.$('<table style="margin-left: 130px;">').append(
                            AJS.$('<tr>').append(
"<td  style='border: 0px; width: 90px; margin-left: 1px; font-weight: bold; background-color:  rgb(204, 255, 255);'><div id='customfield_summary_2:input1'>0</div></td>"
                                                ).append(
            "<td  style='border: 0px; width: 90px; margin-left: 1px; font-weight: bold;   background-color: rgb(204, 255, 255);'><div id='customfield_summary_2:input2'>0</div></td>"
                                                        )
                                 );
if(AJS.$("#edit-issue-dialog").length)
{        
    AJS.$("#customfield_11278\\:input1").parent().parent().parent().parent().parent().before(table);
}
else
{
 AJS.$("#customfield_11278\\:input1").parent().parent().parent().parent().before(table);
}
</script>

  <script type="text/javascript">
   AJS.$("#customfield_summary_2\\:input1").text(
"$" + (
    parseInt(AJS.$
                 ("#customfield_11278\\:input1").val()
            ) + 
    parseInt(AJS.$
                 ("#customfield_11279\\:input1").val()
            ) +
    parseInt(AJS.$
                 ("#customfield_11280\\:input1").val()
            )+
    parseInt(AJS.$
                 ("#customfield_11281\\:input1").val()
            )+
    parseInt(AJS.$
                 ("#customfield_11282\\:input1").val()
            )+
    parseInt(AJS.$
                 ("#customfield_11283\\:input1").val()
            )+
    parseInt(AJS.$
                 ("#customfield_11284\\:input1").val()
            )+
    parseInt(AJS.$
                 ("#customfield_11285\\:input1").val()
            )
    ).toString()
     );
 </script>

几个问题: 1. 关闭编辑屏幕时得到重复的摘要行(通过 jquery 添加的字段)。应该怎么解决。2. 此汇总自定义字段出现在查看屏幕和编辑屏幕上。现在,在视图屏幕中,当我对其他字段进行内联编辑并保存时,此摘要自定义字段(通过客户端 javascript 出现)消失,需要刷新屏幕,然后在它出现并更新值之后。

请让我知道上述查询。谢谢你

4

1 回答 1

0

在评论如何开发具有多个输入字段的自定义字段(插件)中找到了如下@Kuf 的解决方案。

  1. 删除重复的 - 每次 - 在追加之前删除表并将所有内容保存在 setInterval 中,这可以解决问题。

    设置间隔(函数()

    if(AJS.$("#edit-issue-dialog").length) {
    AJS.$("#customfield_11278\:input1").parent().parent().parent().parent().parent( ).之前(表); } else { AJS.$("#customfield_11278\:input1").parent().parent().parent().parent().before(table); },2000)

  2. 刷新内联编辑:使用 setInterval 如下:

    设置间隔(函数(){

    AJS.$("#customfield_summary_2\:input1").text("$" + ( parseInt(AJS.$ ("#customfield_11278\:input1").val()) + parseInt(AJS.$ ("#customfield_11279\ :input1").val()) + parseInt(AJS.$ ("#customfield_11280\:input1").val())+ parseInt(AJS.$ ("#customfield_11281\:input1").val())+ parseInt(AJS.$ ("#customfield_11282\:input1").val() )+ parseInt(AJS.$ ("#customfield_11283\:input1").val() )+ parseInt(AJS.$ ("#customfield_11284\ :input1").val())+ parseInt(AJS.$("#customfield_11285\:input1").val())).toString());, 2000);

谢谢

于 2013-06-27T04:20:19.277 回答