Pass multiple values with onClick in HTML link

后端 未结 8 1599
眼角桃花
眼角桃花 2021-02-04 03:50

Hi Im trying to pass multiple values with the HTML onclick function. Im using Javascript to create the Table

var user = element.UserName;
var valuationId = eleme         


        
相关标签:
8条回答
  • 2021-02-04 04:16

    A few things here...

    If you want to call a function when the onclick event happens, you'll just want the function name plus the parameters.

    Then if your parameters are a variable (which they look like they are), then you won't want quotes around them. Not only that, but if these are global variables, you'll want to add in "window." before that, because that's the object that holds all global variables.

    Lastly, if these parameters aren't variables, you'll want to exclude the slashes to escape those characters. Since the value of onclick is wrapped by double quotes, single quotes won't be an issue. So your answer will look like this...

    <a href=# onclick="ReAssign('valuationId', window.user)">Re-Assign</a>
    

    There are a few extra things to note here, if you want more than a quick solution.

    You looked like you were trying to use the + operator to combine strings in HTML. HTML is a scripting language, so when you're writing it, the whole thing is just a string itself. You can just skip these from now on, because it's not code your browser will be running (just a whole bunch of stuff, and anything that already exists is what has special meaning by the browser).

    Next, you're using an anchor tag/link that doesn't actually take the user to another website, just runs some code. I'd use something else other than an anchor tag, with the appropriate CSS to format it to look the way you want. It really depends on the setting, but in many cases, a span tag will do. Give it a class (like class="runjs") and have a rule of CSS for that. To get it to imitate a link's behavior, use this:

    .runjs {
        cursor: pointer;
        text-decoration: underline;
        color: blue;
    }
    

    This lets you leave out the href attribute which you weren't using anyways.

    Last, you probably want to use JavaScript to set the value of this link's onclick attribute instead of hand writing it. It keeps your page cleaner by keeping the code of your page separate from what the structure of your page. In your class, you could change all these links like this...

    var links = document.getElementsByClassName('runjs');
    for(var i = 0; i < links.length; i++)
        links[i].onclick = function() { ReAssign('valuationId', window.user); };
    

    While this won't work in some older browsers (because of the getElementsByClassName method), it's just three lines and does exactly what you're looking for. Each of these links has an anonymous function tied to them meaning they don't have any variable tied to them except that tag's onclick value. Plus if you wanted to, you could include more lines of code this way, all grouped up in one tidy location.

    0 讨论(0)
  • 2021-02-04 04:20

    enclose each argument with backticks( ` )

    example:

    <button onclick="updateById(`id`, `name`)">update</button>
    
    function updateById(id, name) {
       alert(id + name );
       ...
    }
    
    0 讨论(0)
提交回复
热议问题