Мобильные виджеты jQuery не отображаются в require.js / backbone framework
Создание мобильного приложения с использованием phonegap/requirejs/backbone.
Вот файл представления:
define(['jquery','backbone',"text!templates/summary.tpl",'handlebars','jquery.mobile'],function($,Backbone,Template,Handlebars){
//now create a backbone view
var SummaryView = Backbone.View.extend({
el: $('#mcontent'), // attaches `this.el` to an existing element.
events:{
'pageinit':'',
},
//initialize template
template:Handlebars.compile(Template),
initialize: function(){
_.bindAll(this, 'render'); // fixes loss of context for 'this' within methods
this.render();
},
render: function(){
this.fill_body();
this.footer();
$('body').show();
},
fill_body: function(){
this.$el.append(this.template());
return this;
},
footer: function(){
this.$el.append('<div data-role="footer"><h4>Footer content</h4></div>');
return this;
}
});
и главный файл requirejs:
require.config({
paths:{
jquery:'vendor/jquery/jquery.min',
'jquery.mobile':'vendor/jquery.mobile-1.3.1.min',
'jquery.mobile-config':'jqm-config',
underscore:'vendor/underscore/underscore-min',
backbone:'vendor/backbone/backbone-min',
handlebars:'vendor/handlebars/handlebars',
text:'vendor/text/text',
},
shim: {
'backbone': {
//These script dependencies should be loaded before loading backbone.js
deps: ['jquery','underscore'],
//Once loaded, use the global 'Backbone' as the module value.
exports: 'Backbone'
},
'underscore': {
exports: '_'
},
'handlebars' : {
exports : "Handlebars"
},
'jquery.mobile-config': {
deps: ['jquery']
},
'jquery-mobile': {
deps:['jquery','jquery.mobile-config'],
},
},
waitSeconds: 5
});
require(['views/test'],function(TestView){
new TestView;
и когда представление отображается, я вижу оба файла jquery mobile js/css, представленные на странице. Но когда я отрисовываю этот HTML, он просто появляется без рендеринга jquery mobile css элементов.
Для ссылки: страница html:
<div id="summary_page">
<div data-role="page">
<div data-role="content" class="summary" >
<ul data-role="listview" >
<li class="ui-btn-right" id="brands"> Brands </li>
<li class="ui-btn-right" id="pprofile">Personal Profile</li>
<li class="ui-btn-right" id="snetworks">Social networks</li>
<li class="ui-btn-right" id="tos">Terms and conditions</li>
<li class="ui-btn-right" id="ppolicy">Privacy/cookies</li>
</ul>
</div>
</div>
</div>
Кто-нибудь имеет представление о том, почему CSS JQuery Mobile не отображается на странице. В настоящее время я занимаюсь разработкой на платформе Android для PhoneGap.
1 ответ
Попробуйте вызвать триггер ("создать") на соответствующей странице, чтобы обновить его