Ich versuche, einige Javascript-Code in einer JS-Datei zu platzieren, so dass ich es aus mehreren HTML-Seiten aufrufen kann. Das Problem ist, mein Javascript-Code funktioniert gut, wenn ich es in ein Skript innerhalb der HTML-Seite platzieren, aber wenn es in eine externe .js-Datei eingefügt wird, funktioniert es einfach nicht. Ich habe diese Fragen einige Male angeschaut und kann den Fehler immer noch nicht finden.JavaScript-Funktion funktioniert innerhalb der HTML-Seite, funktioniert aber nicht von externen JS-Datei
Hier ist die HTML-Seite:
<html>
<head>
<meta charset="utf-8" />
<meta name="format-detection" content="telephone=no" />
<meta name="msapplication-tap-highlight" content="no" />
<meta name="viewport" content="user-scalable=no, initial-scale=1, maximum-scale=1, minimum-scale=1, width=device-width, height=device-height, target-densitydpi=device-dpi" />
<link rel="stylesheet" type="text/css" href="css/global.css" />
<link rel="stylesheet" type="text/css" href="css/contacts.css" />
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js"></script>
<script type="text/javascript" src="cordova.js"></script>
<script type="text/javascript" src="js/index.js"></script>
<script type="text/javascript" src ="js/contactsModule.js"></script>
<title>Hall of Heroes</title>
</head>
<body onload = "contactsModule.getContacts();">
<!-- Global Header Starts Here -->
<div class="header">
<div class="cancel">
<img src="img/cancel.png" /><!-- if screen is triggered from onboarding, then go back to onboarding screen instead of home -->
</div>
<h1>My Contacts</h1>
</div>
<div class="wrapper">
<h3>A</h3> <!-- letter header goes here -->
<!-- Begin Contact Unit -->
<div class="feed">
</div>
<!-- End Contact Unit -->
</div>
</body>
</html>
Und hier ist die JS-Datei:
var contactsModule = (function($){
function getContacts()
{
dbContacts();
}
function displayContacts(contactArray){
window.alert('displayContacts now running!');
var jsonObject = $.parseJSON(contactArray);
jsonObject.forEach(function (dat) {
//Begin Contact Unit
$('.feed')
.append('<div class="feed-img"><img src="' + dat.avatarUrl + '"/>\
</div><div class="feed-text"><p><span class="name_highlight">\
' + dat.firstName + ' ' + dat.lastName + '</span></p></div>');
//End Contact Unit
});
}
function dbContacts() {
var avatarUrl;
var firstName;
var lastName;
$.ajax({
type: "GET",
url: "http://www.hallofheroesapp.com/php/contacts.php",
data: {avatarUrl: avatarUrl, firstName: firstName, lastName: lastName},
success: function (response) {
window.alert('AJAX ran successfully!');
displayContacts(response);
},
error: function(response){
alert("Error:" + response);
}
});
}
}(jQuery));
Vielen Dank für Ihre Hilfe!
Sind Sie sicher, dass es in der HTML-Datei funktioniert - ich sehe nichts an die 'contactsModule'-Variable zurückgegeben - wo bekommt es seinen Wert ..? –
ist das Ende dieser Funktion soll '}) sein (jQuery);'? – kirinthos
@kirinthos beide Wege arbeiten –