1

我希望覆盖基本的 jQuery 选择器,以便$('.classname')任何 jQuery 选择器中的所有 CSS 类 ( ),包括.find(.classname).parents(.classname)等,都以“命名空间”为前缀。在上面的例子中,我的 jQuery 代码看起来像$('.classname'),,但是会被翻译成$('.SomeCssNamespace_classname').

选择器将匹配的 HTML$('.classname')如下所示:
<div class="SomeCssNamespace_classname" />

最重要的是,我必须添加智能,可能是以 a 的形式,regex这只会对类名执行此操作,而不是 id 或标签选择器。eg$('#someId')不会被翻译成$('#SomeCssNamespace_someId').

此外,必须重写jQuery.addClass()and方法以添加相同的命名空间。jQuery.removeClass()

4

2 回答 2

2

我的解决方案是编写自己的函数来执行此操作......例如:

prefixClassSelector = function(prefix,class_name) {
    return $('.' + prefix + '_' + class_name);
}

然后你可以这样称呼它,它仍然是可链接的

prefixClassSelector('someNamespace','myclass').hide();
于 2012-09-20T17:18:55.310 回答
0

尝试这样的事情:

// define the namespace
jQuery.myjQueryNamespace = {

  name: 'custom_', // the prefix

  // returns the prefixed selector, classname needs to be prefixed with "."
  addNamespace: function(selector) {

    if (typeof String.prototype.indexOf == "function") {
      return selector.replace(/\./g, '.' + jQuery.myjQueryNamespace.name);
    } else {
      // TODO: write my own indexOf function
      return selector;
    }
  },

  // returns the prefixed selector, classname should *not* to be prefixed with "."
  prefixNamespace: function(selector) {
    return jQuery.myjQueryNamespace.name + 'selector';
  }
}

// keep the original init function
jQuery.fn._init = jQuery.fn.init;

jQuery.fn.init = function(selector, context, rootjQuery) {

  if (typeof selector == 'string'
  && typeof String.prototype.indexOf == "function" // assumes String.prototype.indexOf is defined
  && selector.indexOf('.') != -1) {

    var myNewSelector = jQuery.myjQueryNamespace.addNamespace(selector);
    return jQuery.fn._init.call(this, myNewSelector, context, rootjQuery);
  } else {

    return jQuery.fn._init.call(this, selector, context, rootjQuery)
  }
}

// *got this from the jQuery source code
jQuery.fn.init.prototype = jQuery.fn;

// modify addClass and removeClass
for (var fn_key in jQuery.fn) {

  // if the function has "Class" in it, replace the function
  if (fn_key == 'addClass' || fn_key == 'removeClass') {

    // we'll keep the original function prefixed with underscore
    jQuery.fn['_' + fn_key] = jQuery.fn[fn_key];

    // build the new function which calls the original function passing in the namespaced selector
    var new_function = new Function("selector", "return jQuery.fn['" + '_' + fn_key + "'].call(this, jQuery.myjQueryNamespace.prefixNamespace(selector));");

    // assign it to the original name
    jQuery.fn[fn_key] = new_function;
  }
}

警告:我只通过粘贴到控制台中进行了测试,并且仅在 chrome 中。它可能有意想不到的行为。

最好在加载 jquery 后立即运行它,允许其他插件被命名空间。

代码所做的是将jQuery.fn.init函数替换为以类名为前缀的修改版本。该jQuery.fn.init函数在您调用时运行$(selector)。我们以类似的方式进行addClass修改。removeClass

于 2012-09-21T05:30:10.170 回答