私は私が購入を持っているテーマで.js
文書に誤りがある可能性があります:「
$('.tagcloud a').wrap('<span class="st_tag" />');
私はそれを解決しようとしていますが、私はドンので、私はプログラマではありませんよ方法を知っている。 サイトはhttp://www.framerental.comです。
私は私が購入を持っているテーマで.js
文書に誤りがある可能性があります:「
$('.tagcloud a').wrap('<span class="st_tag" />');
私はそれを解決しようとしていますが、私はドンので、私はプログラマではありませんよ方法を知っている。 サイトはhttp://www.framerental.comです。
jQueryが存在しない可能性があります。
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.8.0/jquery.min.js"></script>
それは可能ですが、wordpressとCMSのほとんどの$はデフォルトで設定されていません。 –
あなたはjQueryのが含まれている場合は、競合がある可能性があります。 $
の代わりにjQuery
を使用してください。
使用する場合jQuery.noConflict();
したがって$
は未定義です。あなたはjQueryのツールキット/ libに
jQuery(document).ready(function($) {
// Code that uses jQuery's $ can follow here.
});
ok!今では何かが働いていますが、他のエラーが表示されます:Referenceerror resizaウィンドウが定義されていません。線:jQuery(ウィンドウ).bind( "resize"、resizeWindow); 関数resizeWindow(e){ var newWindowWidth = jQuery(window).width(); – user1645326
バインド式の前に関数を定義しようとします。 – jurka
テーマの古い「エンキューされた」jQueryをコメントアウトした後、これは古いWPテーマのすべてのエラーを修正しました。率直に言えば、私は "wp_enqueue_script"システムが本当に面倒で、工夫されて、複雑すぎるし、不必要であることがわかります。私はWordPressが管理パネル用のjsコードを隠したりコンパートメント化したり、jQueryをどのように使用するかを私たちが利用できるようにしたいと考えています。 「wp_enqueue_script」はGoogle PageSpeed Insightテストに合格しますか?おそらくそうではありません。どちらの場合でも、単純にすべてのWPプラグインとテーマで同じjQueryを使用する必要があります。誰もが同じページにいれば、一緒に進むことができます。 –
のどちらかを含めていない。
あなたはこの方法であなたのコードを変更するには、ここdocs
てみてくださいそれについての詳細を読むことができます(レディ機能へ$
記号を追加)いくつか提案しているように、あるいは種類の衝突があります。テストするには:次のようにjQueryとテストが含まれます:
console.log($);
console.log($ === jQuery);
$
が未定義でない場合、および$ === jQuery
ログ偽、あなたは間違いなくあなたの手の競合を持っています。 $
をjQuery
に置き換えると、それは解決しますが、それはかなり面倒なことになります(余分な入力はすべて...)。一般的には、少なくとも$jq = _$ = jQuery;
でスクリプトを開始し、少なくともjQueryオブジェクトへの参照を短くします。もちろん
、あなたは、あなたが誤って、あらかじめ設定されている変数を上書きしていないかどうかを確認することを行う前に:console.log($jq, _jQ, _$);
はundefined
が放っておかれるべきでない方はもちろんのを
エリアスは答えを持っているようですが、私がプログラマーでない限り、私はあなたがchinesseで話しているように感じています。私のための簡単な解決策はありますか?私は完全に失われています:-( – user1645326
@ user1645326:はい、あります。jurkaさんの回答の下にあなたのコメントは、あなたがラッパー 'jQuery(document).ready(function($){ '関数であり、' resizeWindow'は 'jQuery(window).with();ではなく、' $(this).width(); 'から' with 'を取得しますが、 'resiza window'のコードを検索し、' resizeWindow'に置き換えてください... –
機能エラーが共通のものですほぼすべてのコンテンツ管理システムで、これにアプローチする方法はいくつかあります。
は使用してコードをラップ:
<script>
jQuery.noConflict();
(function($) {
$(function() {
// YOUR CODE HERE
});
});
</script>
: <script>
jQuery(function($) {
YOUR CODE GOES HERE
});
</script>
<script>
$.noConflict();
jQuery(document).ready(function($) {
// Code that uses jQuery's $ can follow here.
});
// Code that uses other library's $ can follow here.
</script>
準備文書を使用せずにnoConflictを使用してのもう一つの例を使用してjQueryのAPIを使用することができます
あなたも、そうのような競合を避けるために、あなたの非常にエイリアスを作成することを選択することができる:
$("div p").hide();
jQuery("div p").hide();
var jExample = jQuery.noConflict();
// Do something with jQuery
jExample("div p").hide();
さらに別の長いソリューションは、jQueryのに$のすべてreferancesの名前を変更することです
<script>
var $ = jQuery.noConflict();
</script>
をheader.phpのheadタグに追加します。または、管理領域(またはheader.phpが使用されていないどこか)でドル記号を使用する場合は、その場所を使用したい場所の直前に置いてください。
(そこに、私は認識していないよ、いくつかの競合もそれをテストし、存在する場合、ここでのリンク怒鳴るで提供される他のソリューションを使用することがあります。)
出典:代わりにhttp://www.wpdevsolutions.com/use-the-dollar-sign-in-wordpress-instead-of-jquery/
これはフッターに独自のカスタムテーマスクリプトをエンキューする場合に機能します – Turbojohan
これを行う:
$(document).ready(function() { });
あなたはこのやるべきこと:
jQuery(document).ready(function($) {
// your code goes here
});
これは、WordPressが将来jQuery以外のものに$を使用する可能性があり、$がjQueryドキュメント準備完了コールバックでのみ使用できるようにjQueryをロードする必要があるためです。
これは素晴らしい動作ですdoc.ready内のもの。ボード全体(ウィンドウ機能)を必要とする場合は、Savageの答えを上記のように表示してください。 – cbloss793
私はhead
セクションの最後にロードされたカスタムスクリプトファイルを追加し、トップで次のように挿入:
(function (jQuery) {
window.$ = jQuery.noConflict();
})(jQuery);
(これはFankyの答えの変形例である)
以外noConflict、これも参考になります:
(function($) {
// Variables and DOM Caching using $.
var body = $('body');
console.log(body);
})(jQuery);
これは素晴らしいです! – Andy
あなたがテーマを支払っていて、あなたのサイトに他の多くのカスタム設定を行っていない場合は(あなたがl)私は彼らのサポートに連絡する – TommyBs