Phonegap と Photoswipe に苦労しています。ここに私が持っているものがあります:
1)現在、php JSON呼び出しを介してリモート画像をリクエストしています(動作中)
2) JSON イメージが返され、Android デバイスにローカルに保存されます (動作中)。
3) すべての画像が Photswipe サムネイル ギャラリー ページに表示されます (動作中)
ここに問題があります 4) サムネイル画像をクリックすると、Photoswipe ギャラリー形式が表示されず、画像が空白のページにロードされるだけです。
私の推測では、すべての画像を <#gallery に完全に渡す前に、photoswipe スクリプトが読み込まれています。
私の質問は、Photoswipeを再初期化してすべての画像を読み取る方法、またはPhotoswipe機能を追加された画像に添付する方法です
ここでフォーマットに問題があるため、現在作業しているコードを投稿しようとしています。
//Global instance of DirectoryEntry for our data
var DATADIR;
var knownfiles = [];    
//Loaded my file system, now let's get a directory entry for where I'll store my   crap    
function onFSSuccess(fileSystem) {
fileSystem.root.getDirectory("Android/data/com.moto.photoloader",create:true,exclusive:false},gotDir,onError);
}
//The directory entry callback
function gotDir(d){
console.log("got dir");
DATADIR = d;
var reader = DATADIR.createReader();
reader.readEntries(function(d){
    gotFiles(d);
    appReady();
},onError);
}
//Result of reading my directory
function gotFiles(entries) {
console.log("The dir has "+entries.length+" entries.");
for (var i=0; i<entries.length; i++) {
console.log(entries[i].name+' dir? '+entries[i].isDirectory);
    knownfiles.push(entries[i].name);
    renderPicture(entries[i].fullPath);
}
}
function renderPicture(path){
$("#Gallery").append("<li><a href='"http://myurltofullimages"'><img src='"+path+"' alt=\"Image 018\"/></a></li>");
console.log("<li><a href='"/myurltofullimages"'><img src='"+path+"' alt=\"Image 018\"/></a></li>");
}
function onError(e){
console.log("ERROR");
console.log(JSON.stringify(e));
}
function onDeviceReady() {
//what do we have in cache already?
$("#status").html("Checking your local cache....");    
window.requestFileSystem(LocalFileSystem.PERSISTENT, 0, onFSSuccess, null);    
}
function appReady(){
$("#status").html("Ready to check remote files...");
$.get("http://myurltojsonphp/photo_upload/json.php", {}, function(res) {
    if (res.length > 0) {
        $("#status").html("Going to sync some images...");
        for (var i = 0; i < res.length; i++) {
            if (knownfiles.indexOf(res[i]) == -1) {
                console.log("need to download " + res[i]);
                var ft = new FileTransfer();
                var dlPath = DATADIR.fullPath + "/" + res[i];
console.log("downloading crap to " + dlPath);
ft.download("http://myurl/photo_upload/am/woman/thumb/" + escape(res[i]), dlPath, function(){
renderPicture(e.fullPath);
console.log("Successful download of "+e.fullPath);
}, onError);         
            }
        }
    }
    $("#status").html("");
}, "json");
}
{
document.addEventListener("deviceready", onDeviceReady, true);
}
</script>
<script type="text/javascript">
    (function(window, PhotoSwipe){
        document.addEventListener('DOMContentLoaded', function(){
            var
                options = {},
                instance = PhotoSwipe.attach( window.document.querySelectorAll('#Gallery a'), options );
        }, false);
    }(window, window.Code.PhotoSwipe));
</script>