2013-08-08 3 views
0

Я разрабатываю мобильное приложение, основанное на приложениях, используя нокаут js для привязки данных.Получение нокаута для работы с Appframework

Я получаю следующее сообщение об ошибке в моем браузере консоли:

Uncaught Error: Unable to parse bindings.
Message: ReferenceError: technology_name is not defined;
Bindings value: text: technology_name, click: $parent.loadSubSection

я могу проверить, что данные загружаются, но нокаут связывание, кажется, не работает должным образом. Может ли кто-нибудь помочь мне? Мой код похож следующим образом:

index.html

<!DOCTYPE html> 
    <html> 
    <head> 

    <!-- 
    <script type="text/javascript" src="libs/cordova/cordova.js"></script> 
    --> 

    <meta http-equiv="Content-type" content="text/html; charset=utf-8"> 
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"> 
    <meta name="apple-mobile-web-app-capable" content="yes" /> 
    <meta http-equiv="Pragma" content="no-cache"> 
    <title>Our Workplace</title> 

    <!-- Loading the Appframework Libraries --> 

    <!-- Appframework Styles --> 
    <link rel="stylesheet" type="text/css" href="libs/appframework/css/icons.css" /> 
    <link rel="stylesheet" type="text/css" href="libs/appframework/css/src/main.css" /> 
    <link rel="stylesheet" type="text/css" href="libs/appframework/css/src/appframework.css" /> 
    <link rel="stylesheet" type="text/css" href="libs/appframework/css/src/android.css" /> 
    <link rel="stylesheet" type="text/css" href="libs/appframework/css/src/win8.css" /> 
    <link rel="stylesheet" type="text/css" href="libs/appframework/css/src/bb.css" /> 
    <link rel="stylesheet" type="text/css" href="libs/appframework/css/src/ios.css" /> 
    <link rel="stylesheet" type="text/css" href="libs/appframework/css/src/ios7.css" /> 

    <link rel="stylesheet" type="text/css" href="libs/appframework/css/src/badges.css" /> 
    <link rel="stylesheet" type="text/css" href="libs/appframework/css/src/buttons.css" /> 
    <link rel="stylesheet" type="text/css" href="libs/appframework/css/src/lists.css" /> 
    <link rel="stylesheet" type="text/css" href="libs/appframework/css/src/forms.css" /> 
    <link rel="stylesheet" type="text/css" href="libs/appframework/css/src/grid.css" /> 

    <link rel="stylesheet" type="text/css" href="libs/appframework/plugins/css/af.actionsheet.css" /> 
    <link rel="stylesheet" type="text/css" href="libs/appframework/plugins/css/af.popup.css" /> 
    <link rel="stylesheet" type="text/css" href="libs/appframework/plugins/css/af.selectBox.css" /> 

    <!-- Appframework Scripts --> 
    <script type="text/javascript" charset="utf-8" src="libs/appframework/appframework.js"></script> 

    <!-- Google maps plugin --> 
    <!--<script type="text/javascript" src="http://maps.google.com/maps/api/js?v=3&sensor=true&language=en"></script>--> 

    <script> 

     function loadedPanel(what) { 
      //We are going to set the badge as the number of li elements inside the target 
      $.ui.updateBadge("#aflink", $("#af").find("li").length); 
     } 


     function unloadedPanel(what) { 
      console.log("unloaded " + what.id); 
     } 

     if (!((window.DocumentTouch && document instanceof DocumentTouch) || 'ontouchstart' in window)) { 
      var script = document.createElement("script"); 
      script.src = "libs/appframework/plugins/af.desktopBrowsers.js"; 
      var tag = $("head").append(script); 
     } 


    </script> 

    <script type="text/javascript" charset="utf-8" src="libs/appframework/plugins/af.actionsheet.js"></script> 
    <script type="text/javascript" charset="utf-8" src="libs/appframework/plugins/af.css3animate.js"></script> 
    <script type="text/javascript" charset="utf-8" src="libs/appframework/plugins/af.passwordBox.js"></script> 
    <script type="text/javascript" charset="utf-8" src="libs/appframework/plugins/af.scroller.js"></script> 
    <script type="text/javascript" charset="utf-8" src="libs/appframework/plugins/af.selectBox.js"></script> 
    <script type="text/javascript" charset="utf-8" src="libs/appframework/plugins/af.touchEvents.js"></script> 
    <script type="text/javascript" charset="utf-8" src="libs/appframework/plugins/af.touchLayer.js"></script> 
    <script type="text/javascript" charset="utf-8" src="libs/appframework/plugins/af.popup.js"></script> 

    <script type="text/javascript" charset="utf-8" src="libs/appframework/ui/src/appframework.ui.js"></script> 
    <script type="text/javascript" charset="utf-8" src="libs/appframework/ui/transitions/all.js"></script> 
    <script type="text/javascript" charset="utf-8" src="libs/appframework/plugins/af.slidemenu.js"></script> 

    <script type="text/javascript"> 
     /* This function runs once the page is loaded, but appMobi is not yet active */ 
     //$.ui.animateHeaders=false; 
     var search = document.location.search.toLowerCase().replace("?", ""); 
     //if(!search) 
     //$.os.useOSThemes=false; 

     if (search) //Android fix has too many buggy issues on iOS - can't preview with $.os.android 
     { 

      $.os.useOSThemes = true; 
      if (search == "win8") 
       $.os.ie = true; 
      $.ui.ready(function() { 
       $("#afui").get(0).className = search; 
      }); 
     } 

     var webRoot = "./"; 
     // $.os.android=true; 
     $.ui.autoLaunch = false; 
     $.ui.openLinksNewTab = false; 
     //$.ui.resetScrollers=false; 


     $(document).ready(function() { 
      $.ui.launch(); 

     }); 

     /* This code is used to run as soon as appMobi activates */ 
     var onDeviceReady = function() { 
      AppMobi.device.setRotateOrientation("portrait"); 
      AppMobi.device.setAutoRotate(false); 
      webRoot = AppMobi.webRoot + ""; 
      //hide splash screen 
      AppMobi.device.hideSplashScreen(); 
      $.ui.blockPageScroll(); //block the page from scrolling at the header/footer 

     }; 
     document.addEventListener("appMobi.device.ready", onDeviceReady, false); 

     function showHide(obj, objToHide) { 
      var el = $("#" + objToHide)[0]; 

      if (obj.className == "expanded") { 
       obj.className = "collapsed"; 
      } else { 
       obj.className = "expanded"; 
      } 
      $(el).toggle(); 

     } 


     if ($.os.android || $.os.ie || search == "android") { 
      $.ui.ready(function() { 
       $("#main .list").append("<li><a id='toggleAndroidTheme'>Toggle Theme Color</a></li>"); 
       var $el = $("#afui"); 
       $("#toggleAndroidTheme").bind("click", function (e) { 
        if ($el.hasClass("light")) 
         $el.removeClass("light"); 
        else 
         $el.addClass("light"); 
       }); 
      }); 
     } 
    </script> 



    <style> 
     .samplecode { 
      background: #ccc; 
      color: #000; 
      border-radius: 10px; 
      padding: 10px; 
      margin-bottom: 10px; 
      margin-top: 10px; 
     } 

     /* for the grid demo */ 
     .grid > div { 
      border: 1px dashed black; 
     } 
    </style> 


    <!-- Loading JQuery Libraries --> 
    <script type="text/javascript" src="libs/jquery.core/jquery-1.9.1.min.js"></script> 
    <script type="text/javascript" src="libs/jquery-mobile/jquery.mobile-1.3.2.min.js"></script> 

    <script type="text/javascript"> 
     jQuery.noConflict(); 
     console.log("Resolved JQUERY Conflicts..."); 
    </script> 


    <!-- Loading Knockout js content --> 
    <script type="text/javascript" src="libs/knockoutjs/knockout-2.2.1.js"></script> 
    <script type="application/javascript" src="libs/knockoutjs/mapping/knockout.mapping-latest.js"></script> 

    <!-- Loading View Models --> 
    <script type="text/javascript" src="logic/technology.js"></script> 

     </head> 
     <body> 
     <div id="afui" class=""> 
     <!-- this is the splashscreen you see. --> 
     <div id="splashscreen" class='ui-loader heavy'> 
        App Framework 

      <br> 
      <br> 
      <span class='ui-icon ui-icon-loading spin'></span> 
      <h1>Starting app</h1> 

     </div> 
     <div id="header"> 
      <a id='menubadge' onclick='af.ui.toggleSideMenu()' class='menuButton'></a> 
     </div> 


     <!-- this is the splashscreen you see. --> 
     <div id="Div2" class='ui-loader heavy'> 
      Our WorkPlace 
       <br> 
      <br> 
      <span class='ui-icon ui-icon-loading spin'></span> 
      <h1>Loading Data...</h1> 
     </div> 

     <div id="content"> 
      <div title='Our Workplace' id="main" class="panel" selected="true" data-load="loadedPanel" data-unload="unloadedPanel" data-tab="navbar_home"> 

       <div class="dash-widgts"> 
        <p class="dashboard-icons"> 
         <a> 
          <img src="images/main_menu/icon-our-workplace.png" alt="" /></a> 

         <a class="evn"> 
          <img src="images/main_menu/icon-building-essentials.png" alt="" /></a> 

         <a href="#technologyMain" data-transition="slide" title="Technology"> 
          <img src="images/main_menu/icon-technology.png" alt="" /></a> 

         <a class="evn"> 
          <img src="images/main_menu/icon-help.png" alt="" /></a> 
         <a> 
          <img src="images/main_menu/icon-whats-on.png" alt="" /></a> 
         <a class="evn" href="templates/idea/idea_suggesstion.html"> 
          <img src="images/main_menu/icon-idea.png" alt="" /></a> 
        </p> 
       </div> 
      </div> 





     </div><!--/conent --> 

     <div title="Technology" id="technologyMain" class="panel"> 
       <span id="Span1">Technology Inner</span> 
       <ul id="technologyItems" class="list"> 
        <li> 
         <a data-bind="text: technology_name, click: $parent.loadSubSection"></a> 
        </li> 
       </ul> 
      </div> 
</body> 
</html> 

Technology.js Javascript файл

/** The technology related view model*/ 
//console.log("Self Initialised the page..."); 
var viewModel = new TechnologyViewModel(); ; 
(function(){ 

    jQuery(document).on("pageinit", function() { 
     ko.applyBindings(viewModel); 
     console.log("Bound technology View Model..."); 
    }); 

})(); 


//Technology View Model 
function TechnologyViewModel(){ 
    self = this; 

    /*Functon Loading the Technology Subsection By Id*/ 
    self.loadSubSection = function(technologyItem) { 


      var subSectionid = parseInt(technologyItem.technology_item_id);  
      switch (subSectionid) 
      {    

       case 1: 
       localStorage.clear(); 
       localStorage.setItem('technology_object', JSON.stringify(technologyItem)); 
       // $.mobile.changePage("working_wirelessly.html",{transition: 'slide'}); 
       break; 

       case 2: 
       localStorage.clear(); 
       localStorage.setItem('technology_object', JSON.stringify(technologyItem));   
       // $.mobile.changePage("printer_setup.html",{transition: 'slide'}); 
       break; 

       case 3: 
       localStorage.clear(); 
       localStorage.setItem('technology_object', JSON.stringify(technologyItem)); 
       // $.mobile.changePage("mobile_hotspot.html",{transition: 'slide'}); 
       break; 

       case 4: 
       localStorage.clear(); 
       localStorage.setItem('technology_object', JSON.stringify(technologyItem)); 
       //$.mobile.changePage("blackberry_z10.html",{transition: 'slide'}); 
       break; 

       case 5: 
       localStorage.clear(); 
       localStorage.setItem('technology_object', JSON.stringify(technologyItem)); 
       //$.mobile.changePage("desk_phone.html",{transition: 'slide'}); 
       break; 

     } 
    } 


    /* 
    Function For Fetching all the 'Technology' Specific data  
    */  
    self.fetchScreenData = ko.computed(function(){ 
     console.log("Getting Technology Screen Data From File"); 

     jQuery.ajax({ 
       type: "GET",    
       url: "data/Appdata.json", 
       contentType: "application/json", 
       success: function (result) { 
        console.log("SUCCESS: "); 
         /* 
         Parsing Raw data to JSON 
         */ 
         var data = JSON.parse(result); 

         /* 
         Map only the [app basic] and the [technology] 
         array content to the screen 
         */ 
         var mapping = { 'observe': ["app_basic","technology"] };      
         ko.mapping.fromJS(data,mapping,self); 

         /* 
         Function fetching the Technology Screen Header 
         */ 
         self.getTechScreenHeader = ko.dependentObservable(function() { 

          return ko.utils.arrayFilter(self.app_basic(), function(appScreen) { 
            return appScreen.app_screen_id == 3; 
           }); 

         }, self); 
       }, 
       error: function (result) { 
        alert("error loading app json data"); 
       } 
     }); 

     console.log("GOT Technology Screen Data From File"); 
    },self); 



} 

Также я использую следующий файл JSON, чтобы загрузить данные в формате JSON и автоматически их сопоставляйте с помощью плагина-нокаута.

"technology" : [ 
     { 
     "technology_description" : "Bla" 
     "technology_item_id" : "1", 
     "technology_name" : "bla bla", 
     "technology_subject" : "bla bla", 
     "technology_video_desc" : "null", 
     "technology_video_link" : "null", 
     "technology_video_thumbnail" : "null" 
     }, 
     { 
     "technology_description" : "Bla" 
     "technology_item_id" : "2", 
     "technology_name" : "bla bla", 
     "technology_subject" : "bla bla", 
     "technology_video_desc" : "null", 
     "technology_video_link" : "null", 
     "technology_video_thumbnail" : "null" 
     }, 
     { 
     "technology_description" : "Bla" 
     "technology_item_id" : "3", 
     "technology_name" : "bla bla", 
     "technology_subject" : "bla bla", 
     "technology_video_desc" : "null", 
     "technology_video_link" : "null", 
     "technology_video_thumbnail" : "null" 
     }, 

    ], 

Я только с помощью стандартной конфигурации index.html найденной на самом appframework для импорта заголовков.

+0

Откуда вы получаете имя technology_name? Я вообще не вижу никаких наблюдаемых в вашей модели. –

+0

Я получаю, что отображается с использованием плагина отображения нокаута из файла данных json. Я добавил пример файла данных json, который я использую. – msrameshp

+0

Я не имею в виду, что это звучит грубо, но только для моего понимания вы использовали Knockout раньше? Кажется, вам не хватает какой-то разметки. –

ответ

0

У меня есть рабочий пример дома, если вы все еще нуждаетесь в этом. Поскольку я не мог найти один, я заставил его работать сам. Я могу опубликовать его позже.

+0

Я дам вам ответ позже - это не ответ. –

 Смежные вопросы

  • Нет связанных вопросов^_^