将html页面用extjs显示

Ext.onReady(function() {
    Ext.BLANK_IMAGE_URL = 'http://www.cnblogs.com/resources/images/default/s.gif';
    Ext.QuickTips.init();
    /**//**
     * button
     */
    var objArray = Ext.DomQuery.select("input[type=submit]");
    Ext.each(objArray, function(obj) {
        var btn = new Ext.Button({
            text : obj.value,
            applyTo : obj,
            handler : obj.onclick,
            type : obj.type
        });
        btn.getEl().replace(Ext.get(obj));
    });
    var objArray = Ext.DomQuery.select("input[type=reset]");
    Ext.each(objArray, function(obj) {
        var btn = new Ext.Button({
            text : obj.value,
            applyTo : obj,
            handler : obj.onclick,
            type : obj.type
        });
        btn.getEl().replace(Ext.get(obj));
    });
    var objArray = Ext.DomQuery.select("input[type=button]");
    Ext.each(objArray, function(obj) {
        var btn = new Ext.Button({
            text : obj.value,
            applyTo : obj,
            handler : obj.onclick,
            type : obj.type
        });
        btn.getEl().replace(Ext.get(obj));
    });
    /**//**
     * text and textarea and password and file
     */
    var objArray = Ext.DomQuery.select("input[type=text]");
    Ext.each(objArray, function(obj) {
        var txtField = new Ext.form.TextField({
            applyTo : obj,
            validationEvent : 'blur',
            validator : function() {
                Ext.Ajax.request({
                    url : '1.htm',
                    success : function(response) {
                        txtField.clearInvalid();
                        txtField.markInvalid(response.responseText);
                    },
                    failure : function() {
                        alert(1);
                    }
                });
            },
            allowBlank : ((obj.attributes.getNamedItem("notNull") || obj.attributes
                    .getNamedItem("notnull")) ? false : true),
            blankText : '该字段不能为空'
        });
    });
    var objArray = Ext.DomQuery.select("input[type=password]");
    Ext.each(objArray, function(obj) {
        var txtField = new Ext.form.TextField({
            applyTo : obj,
            inputType : 'password'
        });
    });
    var objArray = Ext.DomQuery.select("input[type=file]");
    Ext.each(objArray, function(obj) {

    });
    var objArray = Ext.DomQuery.select("textarea");
    Ext.each(objArray, function(obj) {
        var txtArea = new Ext.form.TextArea({
            applyTo : obj
        });
    });
    /**//**
     * checkbox and radio
     */
    var objArray = Ext.DomQuery.select("input[type=checkbox]");
    Ext.each(objArray, function(obj) {
        var checkbox = new Ext.form.Checkbox({
            applyTo : obj
        });
    });
    var objArray = Ext.DomQuery.select("input[type=radio]");
    Ext.each(objArray, function(obj) {
        var radio = new Ext.form.Radio({
            applyTo : obj
        });
    });
    /**//**
     * select or comboBox
     */
    var objArray = Ext.DomQuery.select("select");
    Ext.each(objArray, function(obj) {
        var btn = new Ext.form.ComboBox({
            typeAhead : true,
            triggerAction : 'all',
            transform : obj,
            forceSelection : true
        });
    });

})
原型页面
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
        <title>test</title>
        <link rel="stylesheet" type="text/css"
            href="resources/css/ext-all.css" />
        <script type="text/javascript" src="adapter/ext/ext-base.js"></script>
        <script type="text/javascript" src="ext-all-debug.js"></script>
        <script type="text/javascript" src="example-form.js"></script>
    </head>
    <body>
        <form>
            <input type="submit" value="asdqweqwe" οnclick="alert(2)">
            <input type="text" notnull>
            <input type="text">
            <input type="password">
            <input type="file">
            <textarea></textarea>
            <input type="checkbox">
            <input type="radio" name="q">qweqwe</input>
            <input type="radio" name="q">qweqwe</input>
            <select name="s">
                <option value="kkkkk">
                    pp
                </option>
                <option value="gg">
                    ww
                </option>
            </select>
        </form>
    </body>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现ExtJS下拉框可查询HTML页面,需要使用ExtJS的ComboBox组件和Store组件。 首先,需要定义一个Store,用来存储下拉框的选项。这个Store可以从HTML页面中获取数据,例如: ```javascript var myStore = new Ext.data.Store({ proxy: { type: 'ajax', url: 'data.html', // HTML页面中存储下拉框选项的数据 reader: { type: 'json', rootProperty: 'data' } }, autoLoad: true }); ``` 然后,在ComboBox中使用这个Store,并设置一些属性,例如: ```javascript var myCombo = new Ext.form.ComboBox({ fieldLabel: 'My ComboBox', store: myStore, displayField: 'name', valueField: 'value', queryMode: 'remote', forceSelection: true, typeAhead: false, selectOnFocus: true, hideTrigger: true, minChars: 1, listConfig: { loadingText: 'Loading...', emptyText: 'No matching results found.', getInnerTpl: function() { return '<div>{name}</div>'; } } }); ``` 在这个ComboBox中,设置了以下属性: - `store`: 使用上面定义的Store。 - `displayField`: 显示在下拉框中的字段,例如`name`。 - `valueField`: 实际提交表单时使用的字段,例如`value`。 - `queryMode`: 查询模式,这里设置为`remote`,表示从服务器端查询数据。 - `forceSelection`: 是否强制选择下拉框中的选项。 - `typeAhead`: 是否启用自动完成。 - `selectOnFocus`: 是否在获得焦点时自动选择下拉框中的文本。 - `hideTrigger`: 是否隐藏下拉框的触发器。 - `minChars`: 在输入框中输入的最小字符数。 - `listConfig`: 下拉框中列表的配置,包括加载提示和空结果提示等。 最后,将这个ComboBox添加到页面中的某个容器中,例如: ```javascript var myPanel = new Ext.panel.Panel({ renderTo: Ext.getBody(), items: [myCombo] }); ``` 这样就可以实现ExtJS下拉框可查询HTML页面了。用户在下拉框中输入字符时,ComboBox会向服务器发送请求,获取符合条件的数据,并在下拉框中显示出来。用户可以从中选择一个选项,或者继续输入字符以缩小搜索范围。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值