0

Sencha Touch を学び、すでに気に入っています。私の意見では、JQTouchよりもはるかに優れています。私が持っていたいくつかのアプリのアイデアに取り組んでいます.2つのタブが必要で、最初のタブにはいくつかのデータを含むext.Listが保持されます。ここまで来ましたが、理解できない問題が 1 つあります。

問題: リストから名前をタッチしても詳細パネルが表示されません。タブパネルにないときは、まったく問題ありませんでした。フォーラムを試してみましたが、解決策が見つかりません。

これは私のコード全体です(多くの例に基づいています):

ShotjesApp = new Ext.Application({
name: "Shotjes",
launch: function() {

    ShotjesApp.detailPanel = new Ext.Panel({
        id: 'detailpanel',
        tpl: 'Omschrijving: {Naam} <br> <br> {Inhoud}',
        dockedItems: [
            {
                xtype: 'toolbar',
                items: [{
                    text: 'terug',
                    ui: 'back',     
                    handler: function() {
                    ShotjesApp.Viewport.setActiveItem('listwrapper', {type:'slide', direction:'right'});
                    }
                }]
            }
        ]
    });

    ShotjesApp.listPanel = new Ext.List({
        id: 'disclosurelist',
        store: ListStore,
        itemTpl: '<div class="contact">{Naam} {Basis}</div>',
        grouped: true,
        onItemDisclosure: function(record, btn, index) {
    var naam = record.data.Naam;
            ShotjesApp.detailPanel.update(record.data);
            ShotjesApp.Viewport.setActiveItem('detailpanel') //THIS WON'T WORK?
    ShotjesApp.detailPanel.dockedItems.items[0].setTitle(naam);
        }
    });

    ShotjesApp.listWrapper = new Ext.Panel ({
        id: 'listwrapper',
        layout: 'fit',
        items: [ShotjesApp.listPanel],
        dockedItems: [
                    {
                    dock : 'top',
                    xtype: 'toolbar',
                    title: 'Shotjes'

    }],

                });

this.mainView = new Ext.TabPanel({ 
    tabBar: { 
            dock: 'bottom', 
            ui: 'dark', 
            layout: { pack: 'center' } 
        }, 
    cardSwitchAnimation: { 
            type: 'fade', 
            cover: true 
        },  

    items:[{
title: 'Shotjes', 
        cls: 'card 1', 
        id: 'card 1', 
        items: [ShotjesApp.listWrapper, ShotjesApp.detailPanel] ,
        iconCls: 'home', 
        layout: 'card', 

    }, {
        title: 'About', 
        cls: 'card 2', 
        id: 'card 2', 
        html: 'about',
        iconCls: 'calendar', 
        layout: 'card', 
    }


    ],

    tabBarDock: 'bottom', 
    fullscreen: true, 
    layout: 'fit' 
}); 

this.Viewport = this.mainView; 
} 

});

4

2 に答える 2

0

これを試して

ShotjesApp.Viewport.setActiveItem(ShotjesApp.detailPanel);

また、コードにセミコロンがありません。

于 2011-08-19T15:33:01.373 に答える
0

かっこいい、ありがとう。これも追加しました。そうしないと、スライドが新しいタブとして開きます。

    ShotjesApp.Viewport = new Ext.Panel ({
        fullscreen: true,
        layout: 'card',
        cardSwitchAnimation: 'slide',
        items: [ShotjesApp.listWrapper, ShotjesApp.detailPanel]
    });

あなたの変更と組み合わせると、それは完全に機能します..

ただし、大きな問題が 1 つあります。ビューポートが全画面表示になっているため、2 番目のタブを押しても表示されません。2 番目のタブを Fullscreen: true に設定すると、アニメーションが表示されますが、最初のタブはまだその上にあります。

ビューポートで fullscreen: false に変更すると、古い問題が再発し、詳細ペインが表示されなくなります。

于 2011-08-19T16:01:47.303 に答える