Может ли один скрипт JS на странице использовать другую версию jQuery, чем другие? [Дубликат]

В Java все находится в форме класса.

Если вы хотите использовать любой объект, тогда у вас есть две фазы:

  1. Объявить
  2. Инициализация

Пример:

  • Объявление: Object a;
  • Инициализация: a=new Object();

То же самое для концепции массива

  • Объявление: Item i[]=new Item[5];
  • Инициализация: i[0]=new Item();

Если вы не дают секцию инициализации, тогда возникает NullpointerException.

374
задан Tshepang 20 April 2014 в 11:10
поделиться

7 ответов

Да, это выполнимо из-за режима noconflict jQuery. http://blog.nemikor.com/2009/10/03/using-multiple-versions-of-jquery/

<!-- load jQuery 1.1.3 -->
<script type="text/javascript" src="http://example.com/jquery-1.1.3.js"></script>
<script type="text/javascript">
var jQuery_1_1_3 = $.noConflict(true);
</script>

<!-- load jQuery 1.3.2 -->
<script type="text/javascript" src="http://example.com/jquery-1.3.2.js"></script>
<script type="text/javascript">
var jQuery_1_3_2 = $.noConflict(true);
</script>

Затем вместо $('#selector').function(); , вы сделали бы jQuery_1_3_2('#selector').function(); или jQuery_1_1_3('#selector').function();.

510
ответ дан ceejayoz 18 August 2018 в 22:26
поделиться
  • 1
    Большое спасибо, ceejayoz! Это похоже на жизнеспособное решение - единственная потенциальная проблема заключается в том, что я не контролирую первую часть вашего кода (назначая более старую версию jQuery другому псевдониму). Как клиент использует jQuery, будет отличаться и не под моим контролем. Могу ли я просто использовать последнюю половину, или обе библиотеки должны вызывать noConflict ()? – Bungle 14 October 2009 в 16:05
  • 2
    Да, вы должны иметь возможность использовать вторую половину. – ceejayoz 14 October 2009 в 17:24
  • 3
    Это действительно прозрачно для исходной страницы? Если они будут использовать $ или jQuery после этот фрагмент кода, будет ли это ссылаться на их собственную версию jQuery или более новую (возможно, у нее меньше установленных плагинов)? – Wim 18 January 2011 в 00:18
  • 4
    @ceejayoz, что произойдет, если у вас есть функция self-invoking, которая использует в ней много $. Мы должны были бы изменить каждый отдельный $ на jquery_1_3_2, в пределах этого раздела noconflict ??? – klewis 30 April 2013 в 18:38
  • 5
    @blachawk Нет, просто псевдоним. (function($) { /*your code here*/ }(jquery_x_x_x)); – Fabrício Matté 9 May 2013 в 23:58

На вашей странице может быть как можно больше различных версий jQuery.

Используйте jQuery.noConflict() :

<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js" type="text/javascript"></script>
<script>
    var $i = jQuery.noConflict();
    alert($i.fn.jquery);
</script> 

<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script>
    var $j = jQuery.noConflict();
    alert($j.fn.jquery);
</script> 

<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js"></script>
<script>
    var $k = jQuery.noConflict();
    alert($k.fn.jquery);
</script> 

DEMO | Источник

19
ответ дан Community 18 August 2018 в 22:26
поделиться

Я хотел бы сказать, что вы всегда должны использовать последние или последние стабильные версии jQuery. Однако, если вам нужно выполнить некоторую работу с другими версиями, вы можете добавить эту версию и переименовать $ в другое имя. Например,

<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js" type="text/javascript"></script>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js" type="text/javascript"></script>
<script>var $oldjQuery = $.noConflict(true);</script>

Посмотрите здесь, если вы напишете что-то, используя $, тогда вы получите последнюю версию. Но если вам нужно что-то сделать со старым, просто используйте $oldjQuery вместо $.

Вот пример

$(function(){console.log($.fn.jquery)});
$oldjQuery (function(){console.log($oldjQuery.fn.jquery)})

Демо

4
ответ дан gdmanandamohon 18 August 2018 в 22:26
поделиться

Абсолютно, да, вы можете. Эта ссылка содержит сведения о том, как вы можете это сделать: https://api.jquery.com/jquery.noconflict/ .

1
ответ дан Jaime Montoya 18 August 2018 в 22:26
поделиться

Взято из http://forum.jquery.com/topic/multiple-versions-of-jquery-on-the-same-page :

  • Исходная страница загружает его «jquery.versionX.js» - $ и jQuery принадлежат версииX.
  • Вы вызываете свой «jquery.versionY.js» - теперь $ и jQuery принадлежат версииY, плюс _$ и _jQuery принадлежат версииX.
  • my_jQuery = jQuery.noConflict(true); - теперь $ и jQuery принадлежат версииX, _$ и _jQuery, вероятно, null, а my_jQuery - версияY.
28
ответ дан Matt 18 August 2018 в 22:26
поделиться

Можно загрузить вторую версию jQuery, а затем восстановить исходную версию или сохранить вторую версию, если раньше не было загружено jQuery. Вот пример:

<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.2/jquery.min.js"></script>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.4/jquery.min.js"></script>
<script type="text/javascript">
    var jQueryTemp = jQuery.noConflict(true);
    var jQueryOriginal = jQuery || jQueryTemp;
    if (window.jQuery){
        console.log('Original jQuery: ', jQuery.fn.jquery);
        console.log('Second jQuery: ', jQueryTemp.fn.jquery);
    }
    window.jQuery = window.$ = jQueryTemp;
</script>
<script type="text/javascript">
    console.log('Script using second: ', jQuery.fn.jquery);
</script>
<script type="text/javascript">
    // Restore original jQuery:
    window.jQuery = window.$ = jQueryOriginal;
    console.log('Script using original or the only version: ', jQuery.fn.jquery);
</script>
18
ответ дан Tomas Kirda 18 August 2018 в 22:26
поделиться

Посмотрев на это и попробовав, я обнаружил, что на самом деле не разрешено запускать несколько экземпляров jquery за раз. После поиска я обнаружил, что это просто трюк и было намного меньше кода.

    <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js" type="text/javascript"></script>
    <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js" type="text/javascript"></script>
    <script>var $j = jQuery.noConflict(true);</script>
    <script>
      $(document).ready(function(){
       console.log($().jquery); // This prints v1.4.2
       console.log($j().jquery); // This prints v1.9.1
      });
   </script>

Итак, добавление «j» после «$» было всем, что мне нужно было сделать.

$j(function () {
        $j('.button-pro').on('click', function () {
            var el = $('#cnt' + this.id.replace('btn', ''));
            $j('#contentnew > div').not(el).animate({
                height: "toggle",
                opacity: "toggle"
            }, 100).hide();
            el.toggle();
        });
    });
69
ответ дан Weird Mike 18 August 2018 в 22:26
поделиться
  • 1
    Просто о сохранении моей кожи в личном проекте, СПАСИБО! – Srihari Yamanoor 28 March 2018 в 06:59
  • 2
    Чтобы избежать переименования переменной jquery во многих местах, вы можете просто заключить свой старый код в следующее: (function($){ })($j) – Marinos An 23 April 2018 в 12:43
Другие вопросы по тегам:

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