2013-06-26 18 views
6

Próbuję utworzyć widget przy użyciu JavaScript i jQuery w SalesForce, utknąłem z błędem: Uncaught TypeError: nie można nazwać metodą 'noConflict' undefinedUncaught TypeError: nie można nazwać metodą 'noConflict' undefined

Poniżej jest mój kod, który używam

(function() { 

// Localize jQuery variable 
var $j; 

/******** Load jQuery if not present *********/ 
if (window.jQuery === undefined || window.jQuery.fn.jquery !== '1.4.2') { 
    var script_tag = document.createElement('script'); 
    script_tag.setAttribute("type","text/javascript"); 
    script_tag.setAttribute("src", 
     "https://ap1.salesforce.com/resource/go/jquery.min.js"); 
    if (script_tag.readyState) { 
     script_tag.onreadystatechange = function() { // For old versions of IE 
      if (this.readyState == 'complete' || this.readyState == 'loaded') { 
       scriptLoadHandler(); 
      } 
     }; 
    } else { 
     script_tag.onload = scriptLoadHandler; 
    } 
    // Try to find the head, otherwise default to the documentElement 
    (document.getElementsByTagName("head")[0] || document.documentElement).appendChild(script_tag); 
} else { 
    // The jQuery version on the window is the one we want to use 
    $j = window.jQuery; 
    main(); 
} 

/******** Called once jQuery has loaded ******/ 
function scriptLoadHandler() { 
    // Restore $ and window.jQuery to their previous values and store the 
    // new jQuery in our local jQuery variable 
    $j = window.jQuery.noConflict(true); 
    // Call our main function 
    main(); 
} 

/******** Our main function ********/ 
function main() { 
    $j(document).ready(function($) { 
     /******* Load CSS *******/ 
     var css_link = $("<link>", { 
      rel: "stylesheet", 
      type: "text/css", 
      href: "style.css" 
     }); 
     css_link.appendTo('head');   

     /******* Load HTML *******/ 
     var jsonp_url = "http://al.smeuh.org/cgi-bin/webwidget_tutorial.py?callback=?"; 
     $.getJSON(jsonp_url, function(data) { 
      $('#example-widget-container').html("This data comes from another server: " + data.html); 
     }); 

    }); 
} 

})(); // We call our anonymous function immediately 

W konsoli błędów przeglądarka jest skierowany do pierwszej linii scriptLoadHandler funkcji.

+0

nie obejmowały jQuery na stronie –

+0

Tak Mam, mam dynamicznie włączając go czekiem ze jeśli jego istniejących lub nie, można zobaczyć go w Trzecia linia powyższego kodu. –

+0

po otwarciu https://ap1.salesforce.com/resource/go/jquery.min.js wydaje się, że nie zawiera on kodu jquery. czy próbowałeś dołączyć jquery z innego miejsca? – Reason

Odpowiedz

2

Zadeklaruj zmienną lokalną jquery jak poniżej:

//Localize jQuery variable 
var $j = jQuery.noConflict();