我在extJs中看到了这示例。我发现他们正在使用Ext.example.msg来实现滑动。因此,我决定将文件example.js存储在app/ext/example.js中。
Ext.example = function(){
var msgCt;
function createBox(t, s){
return ['<div class="msg">',
'<div class="x-box-tl"><div class="x-box-tr"><div class="x-box-tc"></div></div></div>',
'<div class="x-box-ml"><div class="x-box-mr"><div class="x-box-mc"><h3>', t, '</h3>', s, '</div></div></div>',
'<div class="x-box-bl"><div class="x-box-br"><div class="x-box-bc"></div></div></div>',
'</div>'].join('');
}
return {
msg : function(title, format){
if(!msgCt){
msgCt = Ext.DomHelper.insertFirst(document.body, {id:'msg-div'}, true);
debugger;
}
msgCt.alignTo(document, 't-t');
var s = String.format.apply(String, Array.prototype.slice.call(arguments, 1));
var m = Ext.DomHelper.append(msgCt, {html:createBox(title, s)}, true);
m.slideIn('t').pause(1).ghost("t", {remove:true});
},
init : function(){
var t = Ext.get('exttheme');
if(!t){ // run locally?
return;
}
var theme = Cookies.get('exttheme') || 'aero';
if(theme){
t.dom.value = theme;
Ext.getBody().addClass('x-'+theme);
}
t.on('change', function(){
Cookies.set('exttheme', t.getValue());
setTimeout(function(){
window.location.reload();
}, 250);
});
var lb = Ext.get('lib-bar');
if(lb){
lb.show();
}
}
};
}();在index.html中,我添加了路径<script src="./example/example.js" type="text/javascript" ></script>。我在example.js中有一个调试器。它在这一行( var s = String.format.apply(String, Array.prototype.slice.call(arguments, 1));)失败,并显示消息Uncaught TypeError:无法调用未定义的“应用”方法。这是关于什么的?我的控制器里有一个保存按钮
Ext.MessageBox.alert('Save', 'xxxx', showResult);
function showResult(btn){
debugger;
Ext.example.msg('Button Click', 'You clicked the {0} button', btn);
};ExtJs4.2中的新方法是什么?请提出建议。
发布于 2013-11-14 14:41:10
啊,真灵。只需要包含适当的.css文件。.css文件的位置应该在index.html或任何*.html页面中指定。
https://stackoverflow.com/questions/19822601
复制相似问题