appcan.js使用到的js框架:
zepto.js 参考文档: http://www.css88.com/doc/zeptojs_api/
underscore.js 参考文档: http://www.css88.com/doc/underscore/
backbone.js 参考文档: http://www.css88.com/doc/backbone/
backbone-nested.js 参考文档: https://github.com/afeld/backbone-nested
epoxy.js 参考文档: http://epoxyjs.org/
要使其父级获取焦点
1)如果存在mvvm-scope,位置可能写的不对
2)可能是没有在Model或者collection中初始化绑定的参数。
defaults:{}
一般情况出现在Model中 defaults中初始化要有相应的字段,如:defaults:{"typeName":"","typeId":""}
注意:如果没有使用设计器自动生成代码,而是使用自己编写的代码时,可能会因为某些属性写的位置的问题 导致页面不能显示数据,建议使用设计器来生成代码。
需要在page中分别添加header,page0,page1,其中header、page0、page1这三个控件在同一级目录
Page0中书写抽屉内容,设置其大小:宽100%,定位方式:fixed,位置:0,0
Page1中书写主页面内容
一行有两列:使用ul控件 再在ul控件中添加正方形盒子控件,选择属性中的双向列表。
[data-control="CUSTOMLISTVIEW"].col2 li {
width: 49%;
margin-right: 0.5%;
float: left;
position: relative;
}
一行有3列:使用ul控件再在ul控件中添加正方形盒子控件,选择属性中的双向列表,导出后添加col3的样式。
[data-control="CUSTOMLISTVIEW"].col3 li {
width: 33%;
margin-right: 0.3%;
float: left;
position: relative;
}
要注意的是 一行的列数乘以宽度再加上margin值不要超过100%。
var ViewModel = new(MVVM.ViewModel.extend({
el: "body",
initialize: function() {
this.collection.fetch({})
return;
},
collection: Collection,
events:{
'tap #Button':'delBook'
},
delBook:function(){
alert('hello')
}
}))();
问题原因:
当切换slider时,因为初始化加载slider时其他pane默认display:none,此时获取不到slider的宽高,因此无法显示slider。
解决方案:
切换tab标签时,先给当前显示的标签display:block后再初始化slider就可显示。
解决代码:
tabview_Tab_m7gnm8.on('click',function(obj,index){
$('.tab_pane').removeClass('active');
$($('.tab_pane')[index]).addClass('active');
slider($($('.tab_pane')[index]).find('.slider').attr('id'))
})
function slider(id) {
var slider_Slider_DdVcfM = appcan.slider({
selector: $("#"+id),
aspectRatio: 0.38 || 6 / 16,
hasLabel: true,
index: 0
});
slider_Slider_DdVcfM.set([{
"img": "http://newdocx.appcan.cn/docximg/IDE_loading1.png",
"label": "图片"
},
{
"img": "http://newdocx.appcan.cn/docximg/IDE_loading2.png",
"label": "图片"
},
{
"img": "http://newdocx.appcan.cn/docximg/IDE_loading3.png",
"label": "图片"
},
{
"img": "http://newdocx.appcan.cn/docximg/IDE_loading4.png",
"label": "图片"
}]);
slider_Slider_DdVcfM.on("clickItem",
function(index, data) {});
}
ContentFlexVer的padding-top值不能加在当前标签,要加到它的子标签上,不然会出现滚动条。
当切换tab时,需使用fetch重新获取接口数据。
例:ViewModel.collection.fetch({})
itemEvents: {
"tap #Box": function(ev, param) {
var index = _.indexOf(_.pluck(Collection.models, 'id'),this.model.get("id"));
alert("它点击我了" + index);
},
}