Как я получаю выражение селектора jQuery как текст?

Когда вы говорите, что хотите иметь четкое количество продуктов, которые продавались каждый год, вам нужно отфильтровать продукты, у которых есть продажи, а затем подсчитать их. С другой стороны, ваш запрос учитывает членов Dimension-Attribute, которые останутся неизменными, независимо от того, были они проданы или нет.

Посмотрите на ответ ниже, который я дал на другой вопрос. Вы просматриваете весь пример или можете перейти непосредственно к последнему запросу. Это то, что вы хотите достичь.

MDX-запрос для подсчета количества названий продуктов

И, наконец, удачи на экзамене.

31
задан Simon_Weaver 11 February 2013 в 04:57
поделиться

5 ответов

В объекте jQuery существует 'селекторный' атрибут, но я не уверен, что это всегда доступно.

18
ответ дан 27 November 2019 в 22:44
поделиться

При использовании поджигателя, Вы могли console.log(this) внутренняя часть функция и видеть, доступна ли селекторная строка где-нибудь в объекте. Извините я не знаком с API jQuery.

3
ответ дан 27 November 2019 в 22:44
поделиться

хорошо, я все еще пытаюсь выяснить, пытаетесь ли Вы получить имя элемента? или идентификатор и/или класс или все это.

можно получить элемент с этим

var element =$(this).get(0);
var id = $(this).attr('id');
var class=$(this).attr('class');

не уверенный, что происходит, если у Вас есть больше чем один класс. мог бы войти в массив или что-то, и Вы могли получить это с индексами.

-2
ответ дан 27 November 2019 в 22:44
поделиться

Это совсем не оптимально, но работает в некоторых случаях. Вы могли сделать следующее:

jQuery.fn._init = jQuery.fn.init
jQuery.fn.init = function( selector, context ) {
    return (typeof selector === 'string') ? jQuery.fn._init(selector, context).data('selector', selector) : jQuery.fn._init( selector, context );
};

jQuery.fn.getSelector = function() {
    return jQuery(this).data('selector');
};

Это возвратит последний селектор, используемый для элемента. Но это не продолжит работать не существующие элементы.

<div id='foo'>Select me!</div>
<script type='text/javascript'>
 $('#foo').getSelector(); //'#foo'
 $('div[id="foo"]').getSelector(); //'div[id="foo"]'
 $('#iDoNotExist').getSelector(); // undefined
</script>

Это работает с jQuery 1.2.6 и 1.3.1 и возможно другие версии.

Также:

<div id='foo'>Select me!</div>
<script type='text/javascript'>
 $foo = $('div#foo');
 $('#foo').getSelector(); //'#foo'
 $foo.getSelector(); //'#foo' instead of 'div#foo'
</script>

Редактирование
при проверке immidiatly после того, как селектор использовался, Вы могли бы использовать следующее в своем плагине:

jQuery.getLastSelector = function() {
    return jQuery.getLastSelector.lastSelector;
};
jQuery.fn._init = jQuery.fn.init
jQuery.fn.init = function( selector, context ) {
    if(typeof selector === 'string') {
        jQuery.getLastSelector.lastSelector = selector;
    }
    return jQuery.fn._init( selector, context );
};

Затем следующее работало бы:

<div id='foo'>Select me!</div>
<script type='text/javascript'>
 $('div#foo');
 $.getLastSelector(); //'#foo'
 $('#iDoNotExist');
 $.getLastSelector(); // #iDoNotExist'
</script>

В Вашем плагине Вы могли сделать:

jQuery.fn.myPlugin = function(){
 selector = $.getLastSelector;
 alert(selector);
 this.each( function() {
  //do plugins stuff
 }
}

$('div').myPlugin(); //alerts 'div'
$('#iDoNotExist').myPlugin(); //alerts '#iDoNotExist'

, Но все еще:

$div = $('div');
$('foo');
$div.myPlugin(); //alerts 'foo'
8
ответ дан 27 November 2019 в 22:44
поделиться

Я не мог выяснить, как получить ссылку на строковое значение селектора, предоставленного внутреннему $ ('value_i_want_here') при привязке с функцией; походит на жесткую проблему. Однако, если Вы предпочитаете тестировать в IE [x] всегда существует Firebug, Облегченный , который работает, действительно хорошо используя console.log (var|val).

0
ответ дан 27 November 2019 в 22:44
поделиться
Другие вопросы по тегам:

Похожие вопросы: