jQTouch вызывает код javascript при переходе на следующую страницу
-
26-09-2019 - |
Вопрос
Я работал над приложением для iPhone, которое требует от меня динамического изменения содержимого.У меня есть следующий код:
<div id="home">
<div class="toolbar">
<a class="blueButton" href="javascript: void(0);" onClick="$('#logout').show();">Logout</a>
<h1>AllaccessMD</h1>
</div>
<h1>Home</h1>
<ul class="edgetoedge" id="ulHome"></ul>
</div>
Когда вызывается эта страница, я вызываю функцию javascript:
function setupHome(){
if(localStorage.role == "Specialist"){
var homeUL = '<li class="arrow"><a id="s,' + localStorage.userID + '" href="#ePresentations">My E-Presentation</a></li>'
+ '<li class="arrow"><a id="s,' + localStorage.userID + '" href="#date">My Newsletter</a></li>'
+ '<li class="arrow"><a id="s,' + localStorage.userID + '" href="#date">My Events</a></li>'
+ '<li class="arrow"><a id="s,' + localStorage.userID + '" href="#date">Medical Partners</a></li>'
+ '<li class="arrow"><a id="s,' + localStorage.userID + '" href="#date">Search</a></li>'
+ '<li class="arrow"><a id="s,' + localStorage.userID + '" href="#date">Profile</a></li>';
$('#ulHome').html(homeUL);
} else {
var homeUL = '<li class="arrow"><a id="m,' + localStorage.userID + '" href="#date">Medical Partners</a></li>'
+ '<li class="arrow"><a id="m,' + localStorage.userID + '" href="#date">Search</a></li>'
+ '<li class="arrow"><a id="m,' + localStorage.userID + '" href="#date">Profile</a></li>';
$('#ulHome').html(homeUL);
}
$('#ulHome li a').click(function(){
alert('I dont see this alert on a iPhone!');
if(this.href.search("#ePresentations") != 0) {
var idObject = getID(this.id);
setupEPresentation(idObject.id);
}
});
}
Все это работает нормально, за исключением $('#ulHome li a').click() не работает.Он отлично работает в Firefox и Chrome, но не на iPhone.
Где я допустил ошибку?ИЛИ есть лучший способ реализовать это?
Спасибо!
Решение
Используйте tap вместо click, кроме того, функция автоматической смены страницы переопределит ваши ссылки, поскольку они расположены в формате href.Также я бы не стал смешивать javascript в коде с событиями в javascript, так что:
<div id="home">
<div class="toolbar">
<a id="logoutButton" class="blueButton" href="#">Logout</a>
<h1>AllaccessMD</h1>
</div>
<h1>Home</h1>
<ul class="edgetoedge" id="ulHome"></ul>
</div>
и
function setupHome(){
if(localStorage.role == "Specialist"){
var homeUL = '<li class="arrow"><a class="Presentation" id="s,' + localStorage.userID + '" href="#">My E-Presentation</a></li>'
+ '<li class="arrow"><a id="s,' + localStorage.userID + '" data="#">My Newsletter</a></li>'
+ '<li class="arrow"><a id="s,' + localStorage.userID + '" href="#">My Events</a></li>'
+ '<li class="arrow"><a id="s,' + localStorage.userID + '" href="#">Medical Partners</a></li>'
+ '<li class="arrow"><a id="s,' + localStorage.userID + '" href="#">Search</a></li>'
+ '<li class="arrow"><a id="s,' + localStorage.userID + '" href="#">Profile</a></li>';
$('#ulHome').html(homeUL);
} else {
var homeUL = '<li class="arrow"><a id="m,' + localStorage.userID + '" href="#">Medical Partners</a></li>'
+ '<li class="arrow"><a id="m,' + localStorage.userID + '" href="#">Search</a></li>'
+ '<li class="arrow"><a id="m,' + localStorage.userID + '" href="#">Profile</a></li>';
$('#ulHome').html(homeUL);
}
$('#ulHome li a').tap(function(){
alert('I dont see this alert on a iPhone!');
if(this.hasClass("Presentations") ) {
var idObject = getID(this.id);
setupEPresentation(idObject.id);
}
});
$('#logoutButton').tap(function() {
$('#logout').show();
});
Не связан с StackOverflow