[ExtJS] Dialog 全屏 Duplicate name

在dialog使用 maximizable:true 属性时,点击全屏化,出现如下错误:

原因:

在定义的浮动层内,对于控件 使用了name属性

例如:

Ext.define('demo',{
    extend:'Ext.Dialog',
    maximizable:true,//可全屏化
    items:[
        {
            xtype:'selectfield',
            name:'Person'//这里使用了name
        }
    ]
})

解决方案:

声明的dialog加上 nameHolder:true  即可

在使用ExtJS与OpenLayers 2.10版本实现全屏展示时,可以通过一些简单的步骤来实现。下面是具体的方法: 1. 在ExtJS的视图文件中,创建一个Panel组件,用于承载OpenLayers地图。 2. 在Panel组件的配置项中,设置layout为'fit',这样地图将会填充整个Panel。 3. 在Panel组件的渲染事件中,初始化OpenLayers地图对象。 4. 在初始化地图时,设置地图容器的大小为全屏。可以使用document.documentElement.clientWidth和document.documentElement.clientHeight来获取浏览器窗口的宽度和高度,然后将地图容器的宽度和高度设置为这些值。 5. 创建地图图层(Layers)和控制器(Controls)。 6. 将图层和控制器添加到地图对象中。 7. 在页面布局完成后,调用地图对象的updateSize()方法,以确保地图在全屏模式下正确显示。 下面是一个示例代码片段,展示了如何使用ExtJS与OpenLayers 2.10版本实现地图的全屏展示: ``` Ext.define('MyMapPanel', { extend: 'Ext.panel.Panel', layout: 'fit', initComponent: function () { this.on('afterrender', this.initMap, this); this.callParent(arguments); }, initMap: function () { var map = new OpenLayers.Map(this.body.dom, { // 设置地图容器大小为全屏 size: new OpenLayers.Size(document.documentElement.clientWidth, document.documentElement.clientHeight) }); // 创建地图图层和控制器 var layer = new OpenLayers.Layer.OSM(); var controls = [ new OpenLayers.Control.Navigation(), new OpenLayers.Control.Zoom() ]; // 将图层和控制器添加到地图 map.addLayer(layer); map.addControls(controls); // 更新地图大小 map.updateSize(); } }); // 在ExtJS布局中使用全屏地图 Ext.create('Ext.container.Viewport', { layout: 'fit', items: [{ xtype: 'mymappanel' }] }); ``` 通过以上步骤,我们可以使用ExtJS与OpenLayers 2.10版本实现地图的全屏展示。希望对你有所帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

29号同学

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值