diff options
| author | Misko Hevery | 2011-04-21 16:32:05 -0700 |
|---|---|---|
| committer | Misko Hevery | 2011-06-08 13:49:11 -0700 |
| commit | cc9f1fdf38bb179166212382b33e78255e669e73 (patch) | |
| tree | cb9881186ce11f18c985e93e75a20b4601851f60 /src/jqLite.js | |
| parent | f243c6aeda4c7dc87dac495dfb8942f4c8ba675e (diff) | |
| download | angular.js-cc9f1fdf38bb179166212382b33e78255e669e73.tar.bz2 | |
Proper handling of special attributes in jqlite
Diffstat (limited to 'src/jqLite.js')
| -rw-r--r-- | src/jqLite.js | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/src/jqLite.js b/src/jqLite.js index c86c265a..68cda632 100644 --- a/src/jqLite.js +++ b/src/jqLite.js @@ -84,6 +84,7 @@ function getStyle(element) { return current; } +//TODO: delete me! dead code? if (msie) { extend(JQLite.prototype, { text: function(value) { @@ -226,6 +227,8 @@ var JQLitePrototype = JQLite.prototype = { // these functions return self on setter and // value on get. ////////////////////////////////////////// +var SPECIAL_ATTR = makeMap("multiple,selected,checked,disabled,readonly"); + forEach({ data: JQLiteData, @@ -252,7 +255,13 @@ forEach({ }, attr: function(element, name, value){ - if (isDefined(value)) { + if (SPECIAL_ATTR[name]) { + if (isDefined(value)) { + element[name] = !!value; + } else { + return element[name]; + } + } else if (isDefined(value)) { element.setAttribute(name, value); } else if (element.getAttribute) { // the extra argument "2" is to get the right thing for a.href in IE, see jQuery code |
