我已经使用Sencha touch2完成了应用程序。在轮播中,我们从控制器级别的Web服务动态绑定图像。当我们在旋转木马中移动/滑动图像时,下一张图像需要花时间加载/显示在旋转木马中。如果加载原始图像需要时间,它将在轮播上显示默认加载掩码。根据我们的要求,如果在滑动旋转木马时加载原始图像需要时间,我们需要在旋转木马中显示默认图像。一旦加载了原始图像,无需显示默认图像,显然加载掩码也会出现。 谁能告诉我如何实现这一个Sencha touch2?
我的浏览页面代码:
Ext.define('SLS.BRND.WEB.view.ProjectsView', {
extend: 'Ext.Panel',
requires: [
'Ext.Carousel'
],
id: 'projectprofile',
xtype: "projectspage",
config: {
autoDestroy: true,
fullscreen: true,
layout: {
type: 'vbox'
},
items: [{
xtype: 'panel',
layout: 'fit',
flex: Ext.os.is.Phone ? 5 : 5,
items: [{
xtype: 'carousel',
direction: 'horizontal',
directionLock: true,
id: 'ImgId',
flex: Ext.os.is.Phone ? 5 : 5,
config: {
fullscreen: true
}
}]
}]
}
});
我的控制器页码:
var retrievedObject = localStorage.getItem('ProjectDetails');
jsonObj = Ext.decode(retrievedObject);
var cmp = Ext.getCmp('ImgId');
if (jsonObj != null) {
if (jsonObj != null) {
var itemsoverlay = [];
if (jsonObj.ProjectMainGalleryRoyalGardenia != null) {
for (var i = 0; i < jsonObj.ProjectMainGalleryRoyalGardenia.length; i++) {
var imgURL = jsonObj.ProjectMainGalleryRoyalGardenia[i].ImageUrl;
var senchaIoProjectImageURL = imgURL;
var senchabigImage = imgURL;
var images = [{ url: senchaIoProjectImageURL, bigUrl: senchabigImage}]
Ext.each(images, function (picture) {
var img = picture.url;
var bigImg = picture.bigUrl;
itemsoverlay.push({
xtype: 'label',
html: '<div style="width:' + window.innerWidth + 'px;height:' + SLS.BRND.WEB.Common.Constants.carouselCanvasHeight + 'px;"><img src=' + img + ' style="width:100%;height:100%"/></div>'
});
});
}
}
cmp.setItems(itemsoverlay);
cmp.setActiveItem(0);
}
}
答案 0 :(得分:2)
一旦快速解决方案,我可以看到将CSS类添加到包含如下图片的div:
itemsoverlay.push({
xtype: 'label',
html: '<div cls="myDiv" style="width:' + window.innerWidth + 'px;height:' + SLS.BRND.WEB.Common.Constants.carouselCanvasHeight + 'px;"><img src=' + img + ' style="width:100%;height:100%"/></div>'
});
然后在CSS文件中创建相关的CSS类:
.myDiv {
background-image:url();
}
这里我只是将占位符图像转换为Base 64数据并将其添加为div的背景图像。通过这种方式,您可以在实际图片加载之前显示默认图像。
通过从div中删除myDiv CSS类,您可以在加载实际图片后轻松删除默认图片。
希望这有帮助