我使用jquery移动多页模板制作了我的网站。在台式机上使用Chrome浏览器访问此网站时,更改页面时,我的js变量comic和checkedItems仍然存在。但是,当我在移动设备上访问该站点时,这些数组似乎没有保留其值。那么移动设备与台式机浏览器又如何呢?我必须将这些存储在本地存储中吗?这是js:
var comics = new Array();
var checkedItems = new Array();
var url = "http://www.midtowncomics.com/rssfeed/rssallnewrelease.xml";
var cat = "";
var zip;
var lat;
var long;
$(document).on("pageshow","#catpage",function(){
$("li").click(function(e){
cat = e.target.id;
});
});
$(document).on("pagebeforeshow","#totalpage",function(){
if(checkedItems) {
var output = "";
var total = 0.0;
$.each(checkedItems, function(itemIndex, checkedItem){
var price = 0.0;
var title = checkedItem;
$.each(comics, function(comicIndex, comic){
if(checkedItem === comic.title) {
price = parseFloat(comic.price);
}
});
total = total + price;
output += '<p>' + title + ' - $' + price + '</p>';
});
total = total.toFixed(2);
output += '<h1>Total: $' + total + '</h1>';
$('#comicPriceList').html(output);
}
});
$(document).on("pagebeforeshow","#emailpage",function(){
if(checkedItems) {
var output = "";
var total = 0.0;
$.each(checkedItems, function(itemIndex, checkedItem){
var price = 0.0;
var title = checkedItem;
$.each(comics, function(comicIndex, comic){
if(checkedItem === comic.title) {
price = parseFloat(comic.price);
}
});
total = total + price;
output += '<p>' + title + ' - $' + price + '</p>';
});
total = total.toFixed(2);
output += '<h1>Total: $' + total + '</h1>';
$('#comicEmailList').html(output);
}
});
function sendMail() {
var list = $('#comicEmailList').html();
var address = $('#emailAddress')[0].value;
$.ajax({
type: "POST",
url: "https://mandrillapp.com/api/1.0/messages/send.json",
data: {
'key': 'uZEnSwFe1NeKxIrYs54aNw',
'message': {
'from_email': address,
'to': [
{
'email': address,
'type': 'to'
}
],
'autotext': 'true',
'subject': "Your Pull List",
'html': list
}
}
}).done(function(response) {
alert('Email Sent!');
});
}
$(document).on("pagebeforeshow", "#titlepage", function(){
document.getElementById("categoryTitle").innerHTML = cat;
var output = "";
$.each(comics, function(index, comic){
if(cat == comic.category)
{
output += '<label onClick="updateCheckList(event)" for="' + comic.title + '">' + comic.title + " - Publisher: " + comic.mfg + " - $" + comic.price + '</label>';
if($.inArray(comic.title, checkedItems) > -1) {
output += '<input type="checkbox" name="collectable" id="' + comic.title + '" value="' + comic.title + '" checked>';
} else {
output += '<input type="checkbox" name="collectable" id="' + comic.title + '" value="' + comic.title + '">';
}
}
});
$('#titlelist').html(output);
$('#titlelist').trigger('create');
});
function updateCheckList(event) {
var item = event.target.nextSibling;
if(item.checked) {
var i = checkedItems.indexOf(item.id);
if(i != -1) {
checkedItems.splice(i, 1);
}
} else {
checkedItems[checkedItems.length] = item.id;
}
}
$(document).on("pagecreate","#homepage",function(){
$("a").on("swipeleft",function(){
alert("You swiped left!");
});
$.ajax({
url: 'http://ajax.googleapis.com/ajax/services/feed/load?v=1.0&num=999&callback=?&q=' + encodeURIComponent(url),
dataType: 'json',
success: function(data) {
var items = data.responseData.feed.entries;
var prev = "";
var output = "";
$.each(items, function(index, value){
var comic = {};
var content = value.content;
var categoryPattern = /Category:.+.<\//;
var categoryArray = categoryPattern.exec(content);
var category = categoryArray[0];
category = category.substring(17,category.length-2);
comic.category = category;
if(prev != category)
{
output += '<li><a href="#titlepage" id="' + category + '" data-transition="flip">' + category + '</a></li>';
prev = category;
}
var title = value.title;
comic.title = title;
var pricePattern = /\$.+.<\//;
var priceArray = pricePattern.exec(content);
var price = priceArray[0];
price = price.substring(2,price.length-2);
comic.price = price;
var mfgPattern = /Manufacturer:.+.<\//;
var mfgArray = mfgPattern.exec(content);
var mfg = mfgArray[0];
mfg = mfg.substring(21,mfg.length-2);
comic.mfg = mfg;
var pubDatePattern = /Release Date:.+.<\//;
var pubDateArray = pubDatePattern.exec(content);
var pubDate = pubDateArray[0];
pubDate = pubDate.substring(21,pubDate.length-2);
comic.pubDate = pubDate;
var linkPattern = /http.+/;
var linkArray = linkPattern.exec(content);
var link = linkArray[0];
link = link.substring(0,link.length-8);
comic.link = link;
comics[index] = comic;
});
document.getElementById("releasesButton").innerHTML = "Releases For: " + comics[0].pubDate;
$('#catlist').html(output);
$('#releasesButton').removeClass('ui-disabled');
}
});
});
function setItemList() {
if(checkedItems) {
var output = "";
$.each(checkedItems, function(index, item){
output += '<p>' + item + '</p>';
});
$('#itemList').html(output);
}
}
$(document).on( 'taphold', 'label', tapholdHandler )
function tapholdHandler( event ){
var title = event.target.nextSibling.id;
$.each(comics, function(index, comic){
if(title == comic.title)
{
window.open(comic.link);
}
});
};
function getLocation() {
if ( navigator.geolocation ) {
function success(pos) {
// Location found, show map with these coordinates
//drawMap(new google.maps.LatLng(pos.coords.latitude, pos.coords.longitude));
lat = pos.coords.latitude;
long = pos.coords.longitude;
url = "http://nominatim.openstreetmap.org/reverse?format=json&lat=" + lat + "&lon=" + long + "&addressdetails=1"
$.ajax({
url: url,
dataType: 'jsonp',
jsonp: 'json_callback',
cache: true,
success: function(data) {
zip = data.address.postcode;
$("#fname").val(zip);
}
});
}
function fail(pos) {
}
navigator.geolocation.getCurrentPosition(success, fail, {maximumAge: 500000, enableHighAccuracy:true, timeout: 6000});
}
}
var map;
var service;
var infowindow;
$(document).on("pageshow","#totalpage",function(){
var pyrmont = new google.maps.LatLng(lat,long);
map = new google.maps.Map(document.getElementById('map-canvas'), {
center: pyrmont,
zoom: 15
});
var request = {
location: pyrmont,
radius: '500',
query: 'comic book shop',
rankBy: google.maps.places.RankBy.DISTANCE
};
infowindow = new google.maps.InfoWindow();
service = new google.maps.places.PlacesService(map);
service.textSearch(request, callback);
});
function callback(results, status) {
if (status == google.maps.places.PlacesServiceStatus.OK) {
var output = "";
for (var i = 0; i < results.length; i++) {
var place = results[i];
if(place.name) {
var name = place.name;
var address = place.formatted_address;
output += '<p>' + name + '\n' + address + '\n</p>';
}
}
$('#placesList').html(output);
}
}
function createMarker(place) {
var placeLoc = place.geometry.location;
var marker = new google.maps.Marker({
map: map,
position: place.geometry.location
});
google.maps.event.addListener(marker, 'click', function() {
infowindow.setContent(place.name);
infowindow.open(map, this);
});
}
和HTML:
<!DOCTYPE html>
<html>
<head>
<link rel="shortcut icon" href="icon.png" />
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="themes/Test.min.css" />
<link rel="stylesheet" href="themes/jquery.mobile.icons.min.css" />
<link rel="stylesheet" href="http://code.jquery.com/mobile/1.4.3/jquery.mobile.structure-1.4.3.min.css" />
<script src="http://code.jquery.com/jquery-1.11.1.min.js"></script>
<script src="http://code.jquery.com/mobile/1.4.3/jquery.mobile-1.4.3.min.js"></script>
<script src="https://maps.googleapis.com/maps/api/js?v=3.exp&libraries=places"></script>
<script src="rsslist.js"></script>
<style>
html, body, #map-canvas {
height: 100%;
margin: 0px;
padding: 0px
}
</style>
</head>
<body>
<div data-role="page" id="homepage">
<div data-role="panel" id="myPanel" data-dismissible="false">
<h2>Your Pull List</h2>
<div id="itemList"></div>
</div>
<div data-role="header" data-position="fixed">
<h1>Weekly Pull List</h1>
<a href="#myPanel" onclick="setItemList()" class="ui-alt-icon ui-btn ui-corner-all ui-shadow ui-icon-bars ui-btn-icon-notext" data-transition="slide"></a>
</div>
<div data-role="main" class="ui-content">
<a href="#catpage" id="releasesButton" class="ui-disabled ui-alt-icon ui-btn ui-corner-all ui-shadow ui-icon-bars ui-btn-icon-right" data-transition="flip">Releases For:
</a>
<div data-role="collapsible">
<h1>Total Cost Calculator</h1>
<a href="#" onClick="getLocation()" class="ui-alt-icon ui-btn ui-corner-all ui-shadow ui-icon-location ui-btn-icon-right" data-transition="slideup">Use Location</a>
<p>OR ENTER ZIP CODE</p>
<input type="number" name="fname" id="fname">
<a href="#totalpage" class="ui-alt-icon ui-btn ui-corner-all ui-shadow ui-icon-shop ui-btn-icon-right" data-transition="slideup">Calculate Total</a>
</div>
</div>
<div data-role="footer" data-position="fixed">
<h1>Dylan and Adam's Comic List</h1>
<h5>Powered by midtowncomics.com</h5>
</div>
</div>
<div data-role="page" id="titlepage">
<div data-role="header" data-position="fixed">
<h1 id="categoryTitle">Weekly Pull List 2</h1>
<a href="#catpage" class="ui-alt-icon ui-btn ui-corner-all ui-shadow ui-icon-back ui-btn-icon-left" data-transition="flip">Go Back</a>
<a href="#homepage" class="ui-alt-icon ui-btn ui-corner-all ui-shadow ui-icon-home ui-btn-icon-left" data-transition="flip">Go Home</a>
<!--<a href="#" class="ui-alt-icon ui-btn ui-corner-all ui-shadow ui-icon-search ui-btn-icon-left" onclick="myFunction()">Search</a>-->
</div>
<div data-role="main" class="ui-content">
<form class="ui-filterable">
<input id="myFilter" data-type="search" placeholder="e.g. Title">
</form>
<fieldset data-role="controlgroup" data-filter="true" data-input="#myFilter" id="titlelist">
<label for="X-Men">X-Men</label>
<input type="checkbox" name="collectable" id="X-Men" value="X-Men">
<label for="Spider-Man">Spider-Man</label>
<input type="checkbox" name="collectable" id="Spider-Man" value="Spider-Man">
<label for="Avengers">Avengers</label>
<input type="checkbox" name="collectable" id="Avengers" value="Avengers">
</fieldset>
</div>
<div data-role="footer" data-position="fixed">
<h1>Dylan and Adam's Comic List</h1>
<h5>Powered by midtowncomics.com</h5>
</div>
</div>
<div data-role="page" id="totalpage">
<div data-role="header" data-position="fixed">
<h1>Total Price</h1>
<a href="#homepage" class="ui-alt-icon ui-btn ui-corner-all ui-shadow ui-icon-home ui-btn-icon-left" data-transition="slidedown">Go Home</a>
<a href="#emailpage" class="ui-alt-icon ui-btn ui-corner-all ui-shadow ui-icon-mail ui-btn-icon-left" data-transition="flip">Email List</a>
</div>
<div id="comicPriceList" data-role="main" class="ui-content">
<p>Total: </p>
</div>
<h1>Nearby Comic Book Shops: </h1>
<div id="placesList" data-role="content" class="ui-content"></div>
<div id="content">
<div id="map-canvas" style="height:100%"></div>
</div>
<div data-role="footer" data-position="fixed">
<h1>Dylan and Adam's Comic List</h1>
<h5>Powered by midtowncomics.com</h5>
</div>
</div>
<div data-role="page" id="emailpage">
<div data-role="header" data-position="fixed">
<h1>Email List</h1>
<a href="#totalpage" class="ui-alt-icon ui-btn ui-corner-all ui-shadow ui-icon-back ui-btn-icon-left" data-transition="flip">Go Back</a>
<a href="#totalpage" onClick="sendMail()" class="ui-alt-icon ui-btn ui-corner-all ui-shadow ui-icon-mail ui-btn-icon-left" data-transition="flip">Send</a>
</div>
<div id="comicPriceList" data-role="main" class="ui-content">
<label for="basic">Email Address:</label>
<input type="email" name="name" id="emailAddress" value="" />
<div id="comicEmailList"></div>
</div>
<div data-role="footer" data-position="fixed">
<h1>Dylan and Adam's Comic List</h1>
<h5>Powered by midtowncomics.com</h5>
</div>
</div>
<div data-role="page" id="catpage">
<div data-role="header" data-position="fixed">
<h1>Catagories</h1>
<a href="#homepage" class="ui-alt-icon ui-btn ui-corner-all ui-shadow ui-icon-home ui-btn-icon-left" data-transition="flip">Go Home</a>
</div>
<div data-role="main" class="ui-content">
<form class="ui-filterable">
<input id="myFilter2" data-type="search" placeholder="e.g. Catagories">
</form>
<ul data-role="listview" id="catlist" data-filter="true" data-input="#myFilter2" data-inset="true">
<li><a href="#titlepage" data-transition="flip">Marvel</a></li>
</ul>
</div>
<div data-role="footer" data-position="fixed">
<h1>Dylan and Adam's Comic List</h1>
<h5>Powered by midtowncomics.com</h5>
</div>
</div>
</body>
</html>
最佳答案
OK,也已经fiddling
这个了。
是的,仅在click
上激活了label
侦听器,而在移动clicked
上不能可靠地激活tap
我已经更改了侦听器以侦听输入的check\change
(始终会触发),并对if
进行了一些修改,以使其在检查时添加并在uncheck
上删除。
$(document).on('change', '#titlepage .ui-checkbox [type="checkbox"]', function () {
var item = this;
if (!item.checked) {
var i = checkedItems.indexOf(item.id);
if (i != -1) {
checkedItems.splice(i, 1);
}
} else {
checkedItems[checkedItems.length] = item.id;
}
});
演示:http://jsfiddle.net/robschmuecker/vPj5D/11/
移动友好的小提琴http://jsfiddle.net/robschmuecker/vPj5D/11/show/light。
这已经过测试,并且可以在我的android 2.3.4股票浏览器上运行。
关于javascript - 为什么JS变量在桌面上的JQuery移动多页模板页面上仍然存在,但在移动设备上却不存在,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/25109044/