- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的公司刚刚购买了一个基于 ext js 4.2 的第三方应用程序。框架。
该软件是封闭源代码,但它是基于 Web 的,因此我可以添加一个 .js 文件来根据我的需要更改 UI。
我想向呈现的页面添加一些控件。该软件到处都显示 ID 而不是文本。示例:“问题创建者:ID123”。当我悬停该字段时,会得到“ID123. John Doe”。好的,我是一个 JS 忍者,所以我可以向 HTML DOM 添加一个字段,它将在正确的位置显示“John Doe”。
我查看了 HTML 代码以获得正确的控件,并查看了生成的 ID。我编写的代码很容易随着第三方软件的每个新版本而中断。
现在,因为它是一个 Ext JS 应用程序,我可能可以更优雅地解决这个问题,比如不直接向 DOM 添加一个字段,而是向 Ext JS 容器添加一个字段。
问题:在 Javascript 中,我引用了 Ext JS 应用程序。我将如何访问当前 View 或 View 模型或模型以查询数据并添加字段?
粗略的想法/伪代码:
var id = app.getCurrentModel.getValue("creatorID");
var name = myserver.getPersonData(id).name;
app.currentView.addLabelControl(name);
我在谷歌上搜索了很多,但我发现的所有示例都假设您正在编写 ext js 应用程序并且您已经在 Controller 或 View 中。但我只得到了对应用程序的引用。
抱歉新手问题:)
最佳答案
“Sencha 应用检查器”
要快速浏览组件层次结构,您可以使用 Sencha 浏览器插件,
以编程方式查找某个 ExtJS 组件
要快速搜索 ExtJS 组件或将您的发现转化为代码,您的主要工具将是浏览器控制台和命令 Ext.ComponentQuery.query(xtype)
,例如
Ext.ComponentQuery.query("grid")
Ext.ComponentQuery.query("panel")
Ext.ComponentQuery.query("form")
然后您将在浏览器控制台中找到该类型所有组件的数组。选择正确的一个,并检查它是否有一个不是自动生成的 id 或 itemId(所有像 xtype-1234
都是自动生成的)。对于表单字段,name
属性可能很有用。命令如
Ext.ComponentQuery.query("[itemId=ABC]")
Ext.ComponentQuery.query("[name=DEF]")
Ext.getCmp(id)
与 Ext.ComponentQuery.query("panel")[12]
相比,可读性更高,而且不易产生副作用。
大多数时候,用树结构思考也很有用。如果您想要一个包含您看到的唯一 slider 的特定容器,请尝试
Ext.ComponentQuery.query("slider")
Ext.ComponentQuery.query("slider")[0].up()
可能比筛选数十个甚至数百个容器更容易。遍历组件结构的方式有up(xtype)
, down(xtype)
, nextSibling(xtype)
, previousSibling(xtype)
。如果提供了 xtype,则选择相应 xtype 的下一个组件;如果未提供,则选择下一个组件,而不管类型(例如,直接父级、相邻兄弟级)。
随意更改。
您可以扩展、调试或修改任何现有行为,包括但不限于 ExtJS 自己的代码,使用所谓的 override
覆盖任何组件,包括构成此应用程序的 View 或存储. override
是获取更多信息的绝佳搜索词。
或者您可以从应用外部向现有组件添加新组件,例如向现有表单添加按钮。比如打开sencha docs然后在console中插入:
Ext.ComponentQuery.query("searchcontainer")[0].up().insert(1,{xtype:'button',text:'Test',handler:function(){Ext.Msg.alert('Test Button clicked');}});
然后您应该在 Sencha Logo 的左上角找到一个按钮。点击它。
查找现有 Controller
为此,您必须找到应用命名空间的名称。
如果是MyApp
,然后 MyApp.app.controllers.items
包含 Controller 列表。 Controller 包含控制逻辑,以及组件和逻辑之间的映射。创建组件时, Controller 将它们的事件附加到这些新组件。许多更改可以而且应该在组件层中进行,因为 Controller 覆盖很困惑。
查找 View 模型
你已经完成了,ExtJS 4.2 不支持它们。
改变模型
如果要更改模型,请注意:不支持向模型添加字段的函数。您可以覆盖模型原型(prototype),并将更多条目推送到 fields
数组中。但是,如果到那时您已经有任何模型实例(记录)在运行,它们将不会更新,并且任何现有的保证都将失效。
也就是说,您可以在 MyApp.model
中找到它们。你可以例如使用 Docs.model.Comment.prototype.fields
获取 Sencha Docs 的 Comment 模型的所有字段,或者甚至插入另一个字段。
关于javascript - Ext JS 4.2 入门,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34681111/
Hive —— 入门 Hive介绍 Apache Hive是一款建立在Hadoop之上的开源数据仓库系统,可以将存储在Hadoop文件中的结构化、半结构化数据文件映射为一张数据库表,基于表提供了一
HBase —— 入门 HBase介绍 HBase是一个分布式的、面向列的开源数据库,该技术来源于 Fay Chang 所撰写的Google论文“Bigtable:一个结构化数据的分布式存储系统”
零:前端目前形势 前端的发展史 HTML(5)、CSS(3)、JavaScript(ES5、ES6):编写一个个的页面 -> 给后端(PHP、Python、Go、Java) ->
在本教程中,您将了解在计算机上运行 JavaScript 的不同方法。 JavaScript 是一种流行的编程语言,具有广泛的应用程序。 JavaScript 以前主要用于使网页具有交
我曾经是一个对编程一窍不通的小白,但因为对互联网世界的好奇心和求知欲的驱使,我踏入了编程的殿堂。在学习的过程中,我发现了一门神奇的编程语言——Python。Python有着简洁、易读的语法,让初学者能
嗨,亲爱的读者们! 今天我要给大家分享一些关于Python爬虫的小案例。你是否曾为了获取特定网页上的数据而烦恼过?或者是否好奇如何从网页中提取信息以供自己使用?那么,这篇文章将会给你一些启示和灵感。
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 8 年前。 Improv
我想创建一个像https://apprtc.appspot.com/?r=04188292这样的应用程序。我对 webrtc 了解一点,但无法掌握 google app-engine。如何为 java
我刚刚开始使用 Python 并编写了一个简单的周边程序。但是,每当我在终端中键入 python perimeter.py 时,都会收到以下错误,我不知道如何解决。 >>> python perime
Redis有5个基本数据结构,string、list、hash、set和zset。它们是日常开发中使用频率非常高应用最为广泛的数据结构,把这5个数据结构都吃透了,你就掌握了Redis应用知识的一半了
创建发布web项目 具体步骤: 1.在开发工具中创建一个dynamic web project helloword 2.在webContent中创建index.html文件 3.发布web应用到
如果你在 Ubuntu 上使用终端的时间很长,你可能会希望调整终端的字体和大小以获取一种良好的体验。 更改字体是一种最简单但最直观的 Linux 的终端自定义 的方法。让我
1. 前言 ADODB 是 Active Data Objects Data Base 的简称,它是一种 PHP 存取数据库的函式组件。现在 SFS3 系统 (校园自由软件交流网学务系统) 计划的
我对 neo4j 完全陌生,我很抱歉提出这样一个基本问题。我已经安装了neo4j,我正在使用shell“localhost:7474/webadmin/#/console/” 我正在寻找一个很好的例子
我正在阅读 ios 4 的核心音频,目的是构建一个小测试应用程序。 在这一点上,我对所有 api 的研究感到非常困惑。理想情况下,我想知道如何从两个 mp3 中提取一些样本到数组中。 然后在回调循环中
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是无关紧要的,因
我下载了 GNUStep并安装了它,但是我不确定在哪里可以找到 IDE。有谁知道什么程序可以用作 GNUStep IDE/从哪里获取它们?否则,有没有人知道有关如何创建和编译基本 GNUStep 程序
我正在尝试开始使用 Apache Solr,但有些事情我不清楚。通读tutorial ,我已经设置了一个正在运行的 Solr 实例。我感到困惑的是 Solr 的所有配置(架构等)都是 XML 格式的。
请问有没有关于如何开始使用 BruTile 的文档? 我目前正在使用 SharpMap,我需要预缓存切片以加快进程 最佳答案 我今天正在研究这个:)Mapsui项目site严重依赖 SharpMap
尽我所能,我无法让 CEDET 做任何事情。 Emacs 24.3。我下载了最新的 CEDET 快照。我从他的底部(不是这样)Gentle Introduction 中获取了 Alex Ott 的设置
我是一名优秀的程序员,十分优秀!