javascript true false 表单与表单元素

Javascript true false


Javascript 使用下面的规则来把非 Boolean 值转换为 Boolean 值:
所有对象都被认为是 true。
字符串当且仅当为空时才被认为是 false。
null和undefined被认为是 false。
数字当且仅当为 0 时才是 false。


if ('0') alert("'0' is true");
if ('0' == false) alert("'0' is false");结果是,两次都 alert 了!那么 '0' 到底是 true 还是 false 呢?
答案是:在js做比较的时候,有这样的三条规则:
如果比较的两者中有bool,会把 bool 先转换为对应的 number,即 0 和 1
如果比较的双方中有一方为number一方为string,会把string转换为数字
把string直接转换为bool的时候,空字符串''转换为 false,除此外的一切字符串转换为 true


在第一次比较的时候,直接把 '0' 放在 if 的表达式中,相当于直接把 string 转换为 bool, !!'0' === true,所以是成立的
在第二次比较的时候,会先把 false 转换为 0,然后把 '0' 转换为 0, 左右两边都是0,于是也是成立的

 

表单与表单元素
每个表单都有个name属性,服务端程序通过name属性对应各个表单元素。
<form>标记本身也有name属性,这个属性与表单提交没有任何关系,它的存在可以方便程序设计人员。如果在<form>标记中定义name属性,那么当表单对象创建时,它除了会作为document对象数组forms[]
的元素被存储外,它还被存储在一个document对象的单独属性中 ,这个新定义的属性名就是name属性值。如<form name="everything">,我们可以使用document.everything 来引用那个表单(document.form[0])。
表单中所有表单元素都具有name属性,当设置了一个表单元素的name属性,就创建了一个引用该表单元素的form对象的新属性,这个属性的名字就是name属性的值

合理的选择了元素名,那么这种语法比使用硬编码(位置依赖)的数组下标要简洁的多。

当表单中有多个元素具有相同的name属性时,javascript就会将这些元素存放到一个数组中,这个名字就是name属性值,数组元素的顺序就是它们在文档中出现的顺序。
document.everything.browser[0]
document.everything.browser[1]
document.everything.browser[2]

在事件处理代码中,关键字this引用触发该事件的文档元素,由于所有的表单元素都有引用包含表单的form属性,所以表单元素的事件处理程序可以用this.form 引用form表单对象。这也意味着表单元素的事件处理程序可以用this.form.x 引用x的兄弟表单元素。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值