duanhui1185 2016-02-29 07:34
浏览 24
已采纳

如何在JavaScript中使用动态Golang HTML模板ID?

Hi I have a html image button with dynamic id inside range in golang template. I need to add a javascript function to it. But the problem is that how could I use this dynamic Id in javascript?

My HTML

{{range $i, $e := .Process}}
   <input id="id{{.}}" type="image" src="/images/icons/pencil.png" alt="edit" width="15" height="15">
{{end}}

JavaScript

<script type="text/javascript">
       $().ready(function() {
            $('#id{{.}}').click(function() {
                $('#hidebody').toggle();

            });
        });
    </script>   

How to solve this? Is there any better way to do this?

  • 写回答

1条回答 默认 最新

  • dounaidu0204 2016-02-29 08:05
    关注

    Give those buttons a class.

    {{range $i, $e := .Process}}
       <input id="{{.}}" class="img-buttons" type="image" src="/images/icons/pencil.png" alt="edit" width="15" height="15">
    {{end}}
    

    In javascript you can do,

    $(".img-buttons").click ( function() {
        $(this).attr( "id" ); // get Id
    });
    

    Instead of the id you can use html data attributes if that suits you better.

    HTML:

    {{range $i, $e := .Process}}
       <input data-id="{{.}}" class="img-buttons" type="image" src="/images/icons/pencil.png" alt="edit" width="15" height="15">
    {{end}}
    

    JS:

    $(".img-buttons").click ( function() {
        $(this).data( "id" ); // get Id
    });
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?