I'm trying to set some data on my buttons such that it can be accessed onclick
. I'm having no problem using JSON in a button's data attribute where the key value is a string. However, I can't figure out how to set the values to be a function.
What I'd like to happen upon clicking the button in this demo code is for the click event to call the function option1()
which will alert the string "hello outside".
The error I'm getting is this:
Uncaught TypeError: Property 'option1' of object #<Object> is not a function
HTML (JSFiddle is here: http://jsfiddle.net/NDaEh/32/):
<button type='button' data-button='{"option1": "option1", "option2":
"option2"}'>click1</button>
JS:
var data='hello outside';
var option1=function(data){
alert(data)
}
$('button').click(function(){
//var data='hello inside';
$(this).data('button').option1(data); // should alert 'hello outside'
});
Thoughts?
The data-* attribute adds custom information to a <button> element. The * part is replaced with a lowercase string, such as data-id, data-type, data-inventory, etc. A <button> element can have any number of data-* attributes, each with their own name. Using data-* attributes reduces the need for requests to the server.
The id attribute assigns an identifier to the <data> element. The id allows JavaScript to easily access the <data> element.
Answer: Use the jQuery attr() Method You can simply use the jQuery attr() method to find the data-id attribute of an HTML element.
Use the following code to get the values in your HTML:
$('button').click(function(){
var data = $.parseJSON($(this).attr('data-button'));
alert(data.option1)
});
This code is specifically for your requirement. By this way, you can store data in HTML and retrieve in JavaScript code.
Updated the JSFiddle code, working code is available at: http://jsfiddle.net/NDaEh/51/
EDIT:
Solution to call a function dynamically: http://jsfiddle.net/NDaEh/70/ HTML:
<button type='button' data-button='{"func": "func1"}'>click1</button>
<button type='button' data-button='{"func": "func2"}'>click2</button>
JS:
var myFuncs = {
func1: function () { alert('Function 1'); },
func2: function () { alert('Function 2'); },
};
$('button').click(function(){
var data = $.parseJSON($(this).attr('data-button'));
myFuncs[data.func]();
});
Dont save objects as JSON strings in the html tag property value. Use the data() method instead.
$('input[type="button"]').data({ option1: 'o1', option2: 'o2' });
Also, when youre writing this:
$(this).data('button').option1(data);
option1
would need to be a plugin in order to be chained on to the data method (or any jquery method for that matter). You would need tomething like this:
jQuery.fn.option1 = function () {
alert($(this).data('option1'));
return this;
}
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With