form表单中使用频繁的组件: 文本框、单选框、多选框、下拉框、文本域
form通过getValues()获取表单中所有name的值

通过setValues({key:values})给对应的name值进行赋值,其中key对应的name值

在给单选框和多选框赋值时,有几个疑惑的地方:
  1. fieldName和name 是否必须一致 ?

(fieldName删除对结果没什么影响,表单是通过name值去获取值得)

  2. name与子项的name 也一致是为何?
      (个人理解:

      通过getValues获取值时是key:value,单选框和多选框子项有多个,获取的value值时子项值的集合,而不能找到具体到对象

      此时要再进行一次key:value赋值,所以在代码中赋值时就出现了,value.key = {key: value.key},
                 举个例子:
                    var set_values = { radioName:0 };
                    此时set_values是单选框获取的值,是一个结果,要将其赋值必须先找到单选框对象,然后在定位到单选框子对象
                    所以setValues(set_values) 其实单选框对象,而没有具体到子对象,因此要再进行一次setValues
                    转换的格式就是:
                        var set_new_values = {}
                        var set_new_values.radioName = {
                            radioName: set_values.radioName
                        }

form.setValues(set_new_values);  
                    此时就可以定位到单选框子对象

多选框和单选框的逻辑是一直,区别只是单选框值只有一个,而多选框值时一个数组
  )

重复知识点: 

JSON.parse(jsonstr);      //可以将json字符串转换成json对象

JSON.stringify(jsonobj); //可以将json对象转换成json对符串

        Ext.onReady(function(){
//Ext.Msg.alert("提示","hello world...") var ageStore = new Ext.data.Store({
fields: ['text', 'id'],
data: [{"id":18,"text":"18"},{"id":19,"text":"19"},{"id":20,"text":"20"},{"id":21,"text":"21"}],
autoLoad: true
}); //1.创建一个form表单
var formpanel = Ext.create("Ext.form.Panel",{
title:"form表单获取与赋值",
width:650,
height:250,
border:true,
renderTo:Ext.getBody(),
items:[
{
xtype:"textfield",
fieldLabel: "姓名",
width:200,
labelWidth:80,
name:"UserName"
}, {
xtype:"textfield",
fieldLabel: "手机号",
width:200,
labelWidth:80,
name:"Tel"
},{
xtype: "combo",
fieldLabel: "年龄",
fieldName: "UserAge",
name: "UserAge",
labelWidth: 80,
allowBlank: false,
blankText: "年龄不能为空",
autoFitErrors: true,
mode: 'local',
msgTarget: "side",
store: ageStore,
displayField: "text",
valueField: "id"
}, {
xtype: "checkboxgroup",
fieldLabel: "上课时间",
labelWidth: 80,
width: 600,
name: "Weeks",
fieldName: "Weeks",
items: [{
boxLabel: "星期一",
name: "Weeks",
inputValue: 1,
checked: true
}, {
boxLabel: "星期二",
name: "Weeks",
inputValue: 2,
}, {
boxLabel: "星期三",
name: "Weeks",
inputValue: 3,
}, {
boxLabel: "星期四",
name: "Weeks",
inputValue: 4,
}, {
boxLabel: "星期五",
name: "Weeks",
inputValue: 5,
}, {
boxLabel: "星期六",
name: "Weeks",
inputValue: 6,
}, {
boxLabel: "星期日",
name: "Weeks",
inputValue: 0,
}]
}, {
xtype: "radiogroup",
width: 300,
labelWidth: 80,
fieldLabel: "上课/兼职",
fieldName: "RadioTimeSpanType",
name: "RadioTimeSpanType",
items: [
{ boxLabel: "去上课", name: "RadioTimeSpanType", inputValue: 0, checked: true },
{ boxLabel: "去兼职", name: "RadioTimeSpanType", inputValue: 1}
], listeners: {
change: function(obj, newValue, oldValue, eOpts){
// 单选事件
}
}
}
],
buttons:[
{
text:"保存",
handler:function(){
var values = formpanel.getForm().getValues();
// JSON.parse(jsonstr); //可以将json字符串转换成json对象
// JSON.stringify(jsonobj); //可以将json对象转换成json对符串
document.getElementById("save_values").value = JSON.stringify(values);
}
}, {
text:"清空",
handler:function(){
formpanel.getForm().reset();
}
}, {
text:"自动填充",
handler:function(){
//获取填充的值
var values = document.getElementById("save_values").value ;
if(values)
{
//注意,获取的值必须是json格式才可以
var json_values = JSON.parse(values); //可以将json字符串转换成json对象
//文本框和下拉框赋值就是key:value就可以
//单选框和复选框有点不一样
// 将key:value值转成key:{key:value}类型
json_values.Weeks = {
Weeks: json_values.Weeks
} json_values.RadioTimeSpanType = {
RadioTimeSpanType: json_values.RadioTimeSpanType
}
//赋值
formpanel.getForm().setValues(json_values);
}
}
}
]
});
}); //下面是body中显示值的div
<div>
            form的值:<br/>
            <textarea id="save_values" style="width:700px; height: 100px;"> </textarea>
        </div>

form表单 获取与赋值的更多相关文章

  1. 微信小程序-form表单-获取用户输入文本框的值

    微信小程序-form表单-获取用户输入文本框的值 <input name='formnickname' class="textarea" placeholder=" ...

  2. form表单获取多选的值

    flask 中 form 表单直接获取多选框的值时 language = request.values.getlist('values')或 language=request.from.getlist ...

  3. 如何通过submit提交form表单获取后台传来的返回值

    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/qq_34651764/article/details/76373846 小伙伴是不是遇到过这样的问题 ...

  4. 通过form表单获取值

    <!DOCTYPE html><html> <head> <meta charset="utf-8" /> <title> ...

  5. form 表单获取所有数据 封装方法

    function getFormJson(frm) { var o = {}; var a = $(frm).serializeArray(); $.each(a, function () { if ...

  6. 使用form表单提交请求如何获取后台返回的数据?

    问题描述 一般的form表单提交是单向的:只能给服务器发送数据,但是无法获取服务器返回的数据,也就是无法读取HTTP应答包. 想要真正的半双工通讯一般需要使用Ajax, 但是Ajax对文件传输也很麻烦 ...

  7. Ajax提交Form表单及文件上传

    刚刚申请下来的博客,写得第一篇.有点小激动,本人以前是一名工业3D设计师突然有些变故做上了JavaWeb开发: 前几天,发现了一些小问题.我在写后台管理页面时,需要上传一张图片.于是我就用很普通的Fo ...

  8. form表单与后台请求的关系

    开发中遇到一个问题,说这个问题前先看一下代码 后台方面, get请求: post请求: 前端方面: 问题是:当我点击提交表单后,页面会跳转成这样: 经过多番测试,原因竟是form表单的提交问题,如果用 ...

  9. 前端HTML基础之form表单

    目录 一:form表单 1.form表单功能 2.表单元素 二:form表单搭建(注册页面) 1.编写input会出现黄色阴影问题 三:完整版,前端代码(注册页面) 四:type属性介绍 1.inpu ...

随机推荐

  1. SCCM 2012 R2实战系列之十三:辅助站点部署

    由于最近几个月一直处于AD升级项目中,很久没有更新SCCM的技术文档了.SCCM 2012中的辅助站点部署方法还是比较特别的,需要注意的地方也非常多,今天跟大家分享辅助站点的具体部署和配置方法. 1. ...

  2. WebSocket 启用压缩

    m_client.Compression = CompressionMethod.Deflate;

  3. OpenJudge Cartesian Tree

    [代码] #include <cstdio> #include <cstdlib> #include <cstring> #include <algorith ...

  4. USACO 2008 Running(贝茜的晨练)

    [题解] 动态规划,dp[i][j]表示第i分钟疲劳度为j的最长距离. [代码] #include <iostream> #include <cstdlib> #include ...

  5. 第5章 IP地址和子网划分(3)_子网划分

    6.子网划分 6.1 地址浪费 (1)IPv4公网地址资源日益紧张,为减少浪费,使IP地址能够充分利用,就要用到子网划分技术. (2)传统上一个C类地址,如212.2.3.0/24,其可用的地址范围为 ...

  6. 第2章 GNS3和PacketTracer网络模拟器(2)_搭建GNS3实验环境

    2. GNS3实验环境 2.1 教学实验1:配置路由器和VPCS (1)配置VPCS虚拟电脑的IP地址命令 //配置VPCS电脑的IP地址等信息 PC1> ? //查看可用的命令 PC1> ...

  7. lua 安装

    1:下载安装 curl -R -O http://www.lua.org/ftp/lua-5.3.0.tar.gz tar zxf lua-5.3.0.tar.gz cd lua-5.3.0 make ...

  8. JavaScript Best Practices (w3cschool)

    JavaScript Best Practices (w3cschool) Local Variables: ·      总是在前面集中定义变量,(包括 for 的i).(strict mode) ...

  9. CS229 6.1 Neurons Networks Representation

    面对复杂的非线性可分的样本是,使用浅层分类器如Logistic等需要对样本进行复杂的映射,使得样本在映射后的空间是线性可分的,但在原始空间,分类边界可能是复杂的曲线.比如下图的样本只是在2维情形下的示 ...

  10. 1-scala基础

    1.scala ①定义:Scala设计的初衷是要集成面向对象编程和函数式编程的各种特性.Scala运行于Java平台(Java虚拟机),并兼容现有的Java程序. ②特点:优雅.简洁.一行代码抵得上多 ...