Конфликт двух скриптов

Статус
Закрыто для дальнейших ответов.

Chris

Well-Known Member
Регистрация
23.04.2012
Сообщения
68
Доброго времени суток! На странице поставил два скрипта: Qjuery UI draggable и Qjuery UI combobox (стилизация select) в итоге один из них не работает, как решить эту проблему? Пробывал подключать их и в header и в body и менял местами. Может есть какая система подключения скриптов? Я с JS мало работаю в основном по одному на страницу вставляю, первый раз с таким столкнулся. Заранее благодарю

Код:
<script src="js/jquery-1.7.2.js"></script>
<script src="js/jquery.ui.core.js"></script>
<script src="js/jquery.ui.widget.js"></script>
<script src="js/jquery.ui.button.js"></script>
<script src="js/jquery.ui.position.js"></script>
<script src="js/jquery.ui.autocomplete.js"></script>
<script src="js/jquery-1.8.0.js"></script>
<script src="js/jquery.ui.core-dad.js"></script>
<script src="js/jquery.ui.widget-dad.js"></script>
<script src="js/jquery.ui.mouse-dad.js"></script>
<script src="js/jquery.ui.draggable.js"></script>
		<script>
	$(function() {
		$( ".draggable" ).draggable();
	});
	</script>
	<script>
			(function( $ ) {
				$.widget( "ui.combobox", {
					_create: function() {
						var input,
							self = this,
							select = this.element.hide(),
							selected = select.children( ":selected" ),
							value = selected.val() ? selected.text() : "",
							wrapper = this.wrapper = $( "<span>" )
								.addClass( "ui-combobox" )
								.insertAfter( select );

						input = $( "<input>" )
							.appendTo( wrapper )
							.val( value )
							.addClass( "ui-state-default ui-combobox-input" )
							.autocomplete({
								delay: 0,
								minLength: 0,
								source: function( request, response ) {
									var matcher = new RegExp( $.ui.autocomplete.escapeRegex(request.term), "i" );
									response( select.children( "option" ).map(function() {
										var text = $( this ).text();
										if ( this.value && ( !request.term || matcher.test(text) ) )
											return {
												label: text.replace(
													new RegExp(
														"(?![^&;]+ ;)(?!<[^<>]*)(" +
														$.ui.autocomplete.escapeRegex(request.term) +
														")(?![^<>]*>)(?![^&;]+ ;)", "gi"
													), "<strong>$1</strong>" ),
												value: text,
												option: this
											};
									}) );
								},
								select: function( event, ui ) {
									ui.item.option.selected = true;
									self._trigger( "selected", event, {
										item: ui.item.option
									});
								},
								change: function( event, ui ) {
									if ( !ui.item ) {
										var matcher = new RegExp( "^" + $.ui.autocomplete.escapeRegex( $(this).val() ) + "$", "i" ),
											valid = false;
										select.children( "option" ).each(function() {
											if ( $( this ).text().match( matcher ) ) {
												this.selected = valid = true;
												return false;
											}
										});
										if ( !valid ) {
											// remove invalid value, as it didn't match anything
											$( this ).val( "" );
											select.val( "" );
											input.data( "autocomplete" ).term = "";
											return false;
										}
									}
								}
							})
							.addClass( "ui-widget ui-widget-content ui-corner-left" );

						input.data( "autocomplete" )._renderItem = function( ul, item ) {
							return $( "" )
								.data( "item.autocomplete", item )
								.append( "<a>" + item.label + "</a>" )
								.appendTo( ul );
						};

						$( "<a>" )
							.attr( "tabIndex", -1 )
							.attr( "title", "Show All Items" )
							.appendTo( wrapper )
							.button({
								icons: {
									primary: "ui-icon-triangle-1-s"
								},
								text: false
							})
							.removeClass( "ui-corner-all" )
							.addClass( "ui-corner-right ui-combobox-toggle" )
							.click(function() {
								// close if already visible
								if ( input.autocomplete( "widget" ).is( ":visible" ) ) {
									input.autocomplete( "close" );
									return;
								}

								// work around a bug (likely same cause as #5265)
								$( this ).blur();

								// pass empty string as value to search for, displaying all results
								input.autocomplete( "search", "" );
								input.focus();
							});
					},

					destroy: function() {
						this.wrapper.remove();
						this.element.show();
						$.Widget.prototype.destroy.call( this );
					}
				});
			})( jQuery );

			$(function() {
				$( ".combobox" ).combobox();
				$( "#toggle" ).click(function() {
					$( ".combobox" ).toggle();
				});
			});
		</script>
скрипты подключаю одни и те же, пришлось дополнить название, а то не работали оба =(

Была ошибка в коде, все получилось.
 

AngelGabriel

И имя мне - легион
Регистрация
23.11.2008
Сообщения
778
Возможно скрипт сробатывает когда DOM еще не готова.
Поробуй перенести их в конец body, пользуйся отладчиком 90% вопросов сразу отпадут.
 

Positive_fun

Well-Known Member
Регистрация
28.03.2012
Сообщения
64
попробуй прописать jQuery.noConflict();
и заменить все $(''); на jQuery('');
например jQuery( ".draggable" ).draggable(); вместо $( ".draggable" ).draggable();

Возможно скрипт сробатывает когда DOM еще не готова.
Поробуй перенести их в конец body, пользуйся отладчиком 90% вопросов сразу отпадут.
а каким отладчиком пользуетесь Вы?
 

Indev29

Just Code...
Регистрация
15.08.2012
Сообщения
370
На будущее: код заключается в теги (
Код:
).
 

Positive_fun

Well-Known Member
Регистрация
28.03.2012
Сообщения
64
На будущее: код заключается в теги (
Код:
).
[/quote]
учту

Chris, а вы пробовали в конец страницы помещать не сами плагины а свой код написан рукой который обращается к ним или обернуть код ожиданием загрузки страницы?
 

Indev29

Just Code...
Регистрация
15.08.2012
Сообщения
370
Да не, это для ТС было. В твоем сообщении можно и без этого обойтись)
 

Chris

Well-Known Member
Регистрация
23.04.2012
Сообщения
68
Извените за то что не отвечал, был у тещи инет там не очень хороший :)) С этой проблемой вопрос решил, проблема была в ошибке. Я id менял на class, а в подключеном js-коде не поменял=). Но вот сейчас новая проблема, теперь между jquery ui combobox и twitter bootstrap (tabs и dropmenu) меняю местами скрипты ставил в конец body, но от перестановки зависит какой скрипт будет работать. Может эти скрипты не работают на пару? :)
 
Статус
Закрыто для дальнейших ответов.
Верх Низ