dom 封装表单控件
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>无标题文档</title>
<style>
body {
margin: 0;
padding: 0;
font-family: '微软雅黑';
}
form {
border: 1px solid #eee;
border-radius: 10px;
width: 600px;
margin: 50px auto;
padding: 20px;
line-height: 28px;
position: relative;
}
form label {
display: block;
font-weight: bold;
padding: 10px 0;
}
form input {
margin-left: -3px;
margin-right: 5px;
}
#showbox1, #showbox2 {
border: 1px solid #eee;
width: 160px;
position: absolute;
right: 30px;
top: 30px;
background: #DEFEF3;
padding: 20px;
display: none;
}
input[type="reset"]{
float: right;
}
</style>
<script type="text/javascript">
window.onload = function ()
{
var oform1 = document.getElementById('form1'),
oform2 = document.getElementById('form2');
oshowbox1 = document.getElementById('showbox1');
oshowbox2 = document.getElementById('showbox2'); function getchecked(form,name)
{
arr = [];
for(var i = 0; i < form[name].length; i++ )
{
if(form[name][i].checked == true)
{
arr.push(form[name][i].value)
}
}
if(form[name][0].type == 'radio')
{
return arr[0];
}
if(form[name][0].type == 'checkbox')
{
return arr;
}
}; for(var i = 0; i < oform1.income.length; i++ )
{
oform1.income[i].onclick = function ()
{
showbox1.style.display = 'block';
showbox1.innerHTML = '您现在得收入是:' + getchecked(oform1,'income');
}
} for(var i = 0; i < oform2.character.length; i++ )
{
oform2.character[i].onclick =function ()
{
showbox2.style.display = 'block';
showbox2.innerHTML = '您现在得收入是:' + getchecked(oform2,'character').join(' ');
}
}
oform1.onreset = function ()
{
var re = confirm ('你确定要重置吗?');
if(re)
{
showbox1.style.display = 'none';
return true;
}
else
{
return false;
}
} oform2.onreset = function ()
{
var re = confirm('你确定要重置吗?');
if(re)
{
showbox2.style.display = 'none';
return true;
}
else
{
return false;
}
} }
</script>
</head> <body>
<form id="form1">
<label>您的月收入水平是:</label>
<input type="radio" name="income" value="1000元以下">1000元以下<br/>
<input type="radio" name="income" value="1000~3000元">1000~3000元<br/>
<input type="radio" name="income" value="3000~5000元">3000~5000元<br/>
<input type="radio" name="income" value="5000~10000元">5000~10000元<br/>
<input type="radio" name="income" value="10000~20000元">10000~20000元<br/>
<input type="radio" name="income" value="20000元以上">20000元以上
<div id="showbox1"></div>
<input type="reset" name="reset" value="重置">
</form>
<form id="form2">
<label>您的性格是:</label>
<input type="checkbox" name="character" value="开朗">开朗
<br>
<input type="checkbox" name="character" value="随性">随性
<br>
<input type="checkbox" name="character" value="阴郁">阴郁
<br>
<input type="checkbox" name="character" value="果断">果断
<br>
<input type="checkbox" name="character" value="冷静">冷静
<br>
<input type="checkbox" name="character" value="奔放">奔放
<br>
<input type="checkbox" name="character" value="内敛">内敛
<br>
<input type="checkbox" name="character" value="稳重">稳重
<div id="showbox2"></div>
<input type="reset" name="reset" value="重置">
</form>
</body>
</html>
dom 封装表单控件的更多相关文章
- 基于 el-form 封装一个依赖 json 动态渲染的表单控件
nf-form 表单控件的功能 基于 el-form 封装了一个表单控件,包括表单的子控件. 既然要封装,那么就要完善一些,把能想到的功能都要实现出来,不想留遗憾. 毕竟UI库提供的功能都很强大了,不 ...
- 415 DOM 查找列表框、下拉菜单控件、对表格元素/表单控件进行增删改操作、创建元素并且复制节点与删除、 对表格操作、通用性和标准的事件监听方法(点击后弹窗效果以及去掉效果)
DOM访问列表框.下拉菜单的常用属性: form.length.options.selectedindex.type 使用options[index]返回具体选项所对应的常用属性:defa ...
- MVC树控件,mvc中应用treeview,实现复选框树的多层级表单控件
类似于多层级的角色与权限控制功能,用MVC实现MVC树控件,mvc中应用treeview,实现复选框树的多层级表单控件.最近我们的项目中需要用到树型菜单,以前使用WebForm时,树型菜单有微软提供的 ...
- Vue.js学习 Item9 – 表单控件绑定
基础用法 可以用 v-model 指令在表单控件元素上创建双向数据绑定.根据控件类型它自动选取正确的方法更新元素.尽管有点神奇,v-model 不过是语法糖,在用户输入事件中更新数据,以及特别处理一些 ...
- vue.js基础知识篇(3):计算属性、表单控件绑定
第四章:计算属性 为了避免过多的逻辑造成模板的臃肿不堪,可使用计算属性来简化逻辑. 1.什么是计算属性 <!DOCTYPE html><html lang="en" ...
- Vue.js学习笔记——表单控件实践
最近项目中使用了vue替代繁琐的jquery处理dom的数据更新,个人非常喜欢,所以就上官网小小地实践了一把. 以下为表单控件的实践,代码敬上,直接新建html文件,粘贴复制即可看到效果~ <! ...
- 定义表单控件的id和name注意点
最近在学习JavaScript,在编写一个demo时出现一个错误.为表单中的提交按钮控件定义的id属性值为submit,致使程序出错.如下代码:(js代码省略) <form method=&qu ...
- react 项目实战(四)组件化表单/表单控件 高阶组件
高阶组件:formProvider 高阶组件就是返回组件的组件(函数) 为什么要通过一个组件去返回另一个组件? 使用高阶组件可以在不修改原组件代码的情况下,修改原组件的行为或增强功能. 我们现在已经有 ...
- Vue3组件(九)Vue + element-Plus + json = 动态渲染的表单控件
一个成熟的表单 表单表单,你已经长大了,你要学会: 动态渲染 支持单列.双列.多列 支持调整布局 支持表单验证 支持调整排列(显示)顺序 依据组件值显示需要的组件 支持 item 扩展组件 可以自动创 ...
随机推荐
- Volley HTTP库系列教程(4)Volley内置的几种请求介绍及示例,StringRequest,ImageRequest,JsonObjectRequest
Making a Standard Request Previous Next This lesson teaches you to Request a String 返回String Requ ...
- 【Todo】字符串相关的各种算法,以及用到的各种数据结构,包括前缀树后缀树等各种树
另开一文分析字符串相关的各种算法,以及用到的各种数据结构,包括前缀树后缀树等各种树. 先来一个汇总, 算法: 本文中提到的字符串匹配算法有:KMP, BM, Horspool, Sunday, BF, ...
- java.lang.NoSuchMethodError: org.springframework.beans.factory.annotation.InjectionMetadata.<init>(Ljava/lang/Class;)V
相应我,是因为你SPRING MVC的包没有加全.你可以新建一个WEB项目.加入SPRING 3.0 的所有包.主要是WEB类的.就可以解决这个问题了.关键就是少包.特别是你的项目原来是SRPING ...
- UVa 1442 (线性扫描) Cave
对于一个水坑,水平面肯定是相等的.(废话,不然为什么叫水ping面) 因为水面不能碰到天花板,所以将水面向两边延伸要么碰到墙壁要么延伸到洞穴外面去. 设h(i)表示向左延伸不会碰到天花板的最高水平面, ...
- splay入门
在比较了网上的几份模板的速度之后,发现指针版明显快了很多,但是一敲起来....各种不习惯...所以还是学的hzwer 的数组版... bzoj3223:维护reverse操作就可以了 #include ...
- POJ 1948 Triangular Pastures【二维01背包】
题意:给出n条边,用这n条边构成一个三角形,求三角形的最大面积. 先求面积,用海伦公式,s=sqrt(p*(p-a)*(p-b)*(p-c)),其中a,b,c分别为三角形的三条边,p为三角形的半周长, ...
- (转)ios获取设备系统信息
UIDevice *device_=[[UIDevice alloc] init]; NSLog(@"设备所有者的名称--%@",device_.name); NSLog(@&qu ...
- (转载)C语言 数组与指针的区别
1) 字符串指针变量是个变量,指向字符串的首地址:而字符串数组名是个常量,为字符串数组第一个元素的地址: 2)字符串指针变量可以赋值,而字符串数组名不能赋值:对于字符数组只能对各个元素赋值,不能用以下 ...
- 移动金融APP分析
最近研究了移动互联网金融APP的情况,分享给大家. 这是官方关于互联网金融的范围,包括支付.借贷.众筹.基金.保险和信托. 典型的APP 绑卡的流程普遍采用的四要素鉴权:姓名,身份证,卡号以及银行预留 ...
- Android Studio 学习 - 程序安装
痛定思痛,从今天开始专心学习AndriodStudio.希望以此为契机,把Java学扎实.更希望自己能坚持下去,不要半途而废. 记录一些日常的工作以及碰到的问题,权当勉励自己.荀子曰:吾尝终日而思矣, ...