关于jQuery对象(类数组对象)以及DOM对象相互转化问题——[object Object]和[object HTMLInputElement]

之前在某官网课程上看有关jQuery和bootstrap的相关教程,有一节课是教我们如何制作价格菜单的按钮以及总价问题

选中按钮,按钮样式会发生变化,右上角价格会自动运算

6个菜单的html结构差不多,先贴出一个菜单的html,如下:

 <div class="col-xs-12 col-sm-4"><div class="panel panel-warning"><div class="panel-body"><span class="title">Southen Style</span><span class="desc">Darius Rucker</span><span class="price">$20.90</span></div><div class="panel-footer text-center"><div class="btn-group" data-toggle="buttons"><label class="btn btn-primary"><span class="glyphicon glyphicon-unchecked"></span><input type="checkbox" id="chk6" name="products" checked="checked"><label for="chk6">Not Selected</label></label></div></div></div></div>

javascript代码如下:

let checkOptions={//创建一个对象,可以在此代码块统一修改信息id:"",checkedGlyph:"glyphicon-check",unCheckedGlyph:"glyphicon-unchecked",checkedBtnClass:"btn-success",unCheckedBtnClass:"btn-primary",checkedText:"Selected",unCheckedText:"Not Selected"};$(document).ready(function () {$("[type='checkbox']").on('change', function () {if ($(this).prop('checked')) {setChecked($(this));} else {unChecked($(this));}caculateTotal($(this));});let checked=$("input:checked");//console.log("checked=="+checked);for (let i=0;i<checked.length;i++) {//  console.log("checked["+i+"]=="+checked[i]);//setChecked(checked[i]);setChecked(checked);caculateTotal(checked[i]);}});function setChecked(ct1) {ct1.prev().removeClass(checkOptions.unCheckedGlyph).addClass(checkOptions.checkedGlyph).next().next().text(checkOptions.checkedText).parent().removeClass(checkOptions.unCheckedBtnClass).addClass(checkOptions.checkedBtnClass).addClass('active');}function unChecked(ct1) {ct1.prev().removeClass(checkOptions.checkedGlyph).addClass(checkOptions.unCheckedGlyph).next().next().text(checkOptions.unCheckedText).parent().removeClass(checkOptions.checkedBtnClass).removeClass("active").addClass(checkOptions.unCheckedBtnClass);}function caculateTotal(ct1) {let tt=$("#total");let total = tt.text();total=stripCurrency(total);let price=$(ct1).closest(".panel").find(".price").text();price=stripCurrency(price);if($(ct1).prop("checked")){total=parseFloat(total)+parseFloat(price);}else{total=parseFloat(total)-parseFloat(price);}tt.text(formatcurrency(total));}function stripCurrency(value){value=value.replace(/(\s|,|\$)/g ,"");//正则表达式value=parseFloat(value);return value;}function formatcurrency(value,decimals,decpoint,separator,symbol){decimals=(typeof decimals=='undefined' ? 2:decimals);//小数decpoint=(typeof decpoint=='undefined'? '.':decpoint);separator=(typeof separator=='undefined' ? ',':separator);symbol=(typeof symbol=='undefined' ? '$':symbol);let parts=value.toFixed(decimals).toString().split(decpoint);//toFixed(把数字转换为字符串,结果的小数点后有指定位数的数字)parts[0]=parts[0].replace(/\B(?=(?:\d{3})+(?!\d))/g,separator);//正则表达式return (symbol+parts.join(decpoint)).toLocaleString();}

各位父老乡亲同志们!有没有发现代码好像有点奇怪???

       let checked=$("input:checked");//console.log("checked=="+checked);for (let i=0;i<checked.length;i++) {//  console.log("checked["+i+"]=="+checked[i]);// setChecked(checked[i]);setChecked(checked);//为什么这段的checked不用checked[i]替换?就像下一行代码一样???caculateTotal(checked[i]);}

于是乎自以为是的我就加上去了,没想到!错误!

什么鬼东西?为什么下一行的代码也是用了【i】啊,

然后我就log一下checked和checked【i】分别代表了什么

嗯.....原来是我函数里面的对象搞错了,checked是jquery对象(类数组对象),他所返回的每个子集都是DOM对象

而jquery对象与DOM对象之间的方法都是独立的,不能jquery使用DOM的方法,相反亦然。

所以你只要在jquery对象后面再加个[index]就能转变为DOM对象

即 

 var $jqName=$("#idName"); //jquery对象var name = $jqName[0]; //dom对象 console.log(name.checked); //检测这个checkbox是否给选中

所以此例中,checked[i]返回的都是input这个DOM对象,它当然没有prev()这个函数了,只有jquery对象才内置有函数的,你看,caculateTotal(checked[i])之所以可以是因为这个函数里面他又用$(ct1)转化成了jquery对象,而我这个setChecked函数他就直接用ct1.prev()来表示

因为本例中函数内的方法都是jquery内置的函数,所以暂时考虑把对象都转化为jquery对象,有两种修改方法,一种是直接把要改的函数里的对象都换成类数组对象(保留setChecked(checked)),另一种就是把要改的函数里的对象都换成DOM对象,但是外面要用$()包围住(保留setChecked(checked[i]) )

方法一:jquery对象转化为DOM对象,我要把 setChecked(checked) 替换成 setChecked(checked[i]) 那么后面此函数内的ct1要换成$(ct1)才行得通,即

    function setChecked(ct1) {$(ct1).prev().removeClass(checkOptions.unCheckedGlyph).addClass(checkOptions.checkedGlyph).next().next().text(checkOptions.checkedText).parent().removeClass(checkOptions.unCheckedBtnClass).addClass(checkOptions.checkedBtnClass).addClass('active');}function unChecked(ct1) {$(ct1).prev().removeClass(checkOptions.checkedGlyph).addClass(checkOptions.unCheckedGlyph).next().next().text(checkOptions.unCheckedText).parent().removeClass(checkOptions.checkedBtnClass).removeClass("active").addClass(checkOptions.unCheckedBtnClass);}

其实单看下面的代码中的this你也可以知道$("[type='checkbox']")这个jquery对象它只会返回DOM对象input,如果要利用返回值引用jquery内置的函数,还是要在本身加上$()才行

 $("[type='checkbox']").on('change', function () {if ($(this).prop('checked')) {setChecked($(this));} else {unChecked($(this));}caculateTotal($(this));});

     

方法二:DOM对象转化为jquery对象,把caculateTotal(checked[i])换成caculateTotal(checked),代码就变成这样的了,不需要for循环了

let checkOptions={//创建一个对象,可以在此代码块统一修改信息id:"",checkedGlyph:"glyphicon-check",unCheckedGlyph:"glyphicon-unchecked",checkedBtnClass:"btn-success",unCheckedBtnClass:"btn-primary",checkedText:"Selected",unCheckedText:"Not Selected"};$(document).ready(function () {$("[type='checkbox']").on('change', function () {if ($(this).prop('checked')) {setChecked($(this));} else {unChecked($(this));}caculateTotal($(this));});let checked=$("input:checked");console.log("checked=="+checked);setChecked(checked);//改了这里噢噢噢噢caculateTotal(checked);/*for (let i=0;i<checked.length;i++) {console.log("checked["+i+"]=="+checked[i]);// setChecked(checked[i]);setChecked(checked);caculateTotal(checked[i]);}*/});function setChecked(ct1) {ct1.prev().removeClass(checkOptions.unCheckedGlyph).addClass(checkOptions.checkedGlyph).next().next().text(checkOptions.checkedText).parent().removeClass(checkOptions.unCheckedBtnClass).addClass(checkOptions.checkedBtnClass).addClass('active');}function unChecked(ct1) {ct1.prev().removeClass(checkOptions.checkedGlyph).addClass(checkOptions.unCheckedGlyph).next().next().text(checkOptions.unCheckedText).parent().removeClass(checkOptions.checkedBtnClass).removeClass("active").addClass(checkOptions.unCheckedBtnClass);}function caculateTotal(ct1) {let tt=$("#total");let total = tt.text();total=stripCurrency(total);let price=ct1.closest(".panel").find(".price").text();//这里也改了哦哦哦price=stripCurrency(price);if(ct1.prop("checked")){//这里也是改了哈哈哈total=parseFloat(total)+parseFloat(price);}else{total=parseFloat(total)-parseFloat(price);}tt.text(formatcurrency(total));}function stripCurrency(value){value=value.replace(/(\s|,|\$)/g ,"");value=parseFloat(value);return value;}function formatcurrency(value,decimals,decpoint,separator,symbol){decimals=(typeof decimals=='undefined' ? 2:decimals);//小数decpoint=(typeof decpoint=='undefined'? '.':decpoint);separator=(typeof separator=='undefined' ? ',':separator);symbol=(typeof symbol=='undefined' ? '$':symbol);let parts=value.toFixed(decimals).toString().split(decpoint);//toFixed(把数字转换为字符串,结果的小数点后有指定位数的数字)parts[0]=parts[0].replace(/\B(?=(?:\d{3})+(?!\d))/g,separator);return (symbol+parts.join(decpoint)).toLocaleString();}

不过还是有疑问,jquery这个类数组对象就可以不用for循环然后他自己就会遍历全身然后把相应的对象放入到正确的函数当中了?,比如说这例中的$(input:checked)作为参数放入函数中,之后所有的input:checked对象都套上了该套上的函数....嗯,有待思考啊这个问题(有空解决!!)

这篇文章可能会有点思路不清,不懂的小伙伴可以留言哦,我能解决的话一定解决!

后面有时间我会相应的介绍一下的正则表达式的一些规则哦,列一个知识清单哈哈哈

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/251405.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何去掉bootstrap table中表格样式中横线竖线

修改之前&#xff0c;表格看上去比较拥挤&#xff0c;因为bootstrap table插件中自带斑马线表格样式&#xff0c;有横线和竖线分栏&#xff0c;现在我们不需要这些。应UI设计的要求&#xff0c;要去掉中间的横线和竖线&#xff0c;使用了修改需求中一种简单粗暴的修改方法&…

Vue项目代码改进(五)—— 将侧边栏菜单改造为动态后,如何按需显示不同图标

将侧边栏菜单改造为动态后&#xff0c;目前侧边栏每项的小图标都相同 <el-aside class"aside" width"200px"><el-col :span"24"><el-menudefault-active"2"class"el-menu-vertical-demo"open"handleOpe…

es6 --- Reflect的静态方法

Reflect.get(target, name, receiver): 查找并返回 target对象的 name属性,若没有,返回undefined var myObject {foo: 1,bar: 2,get baz() {return this.foo this.bar;}, }Reflect.get(myObject, foo); // 1// 若name属性部署了读取函数(getter),则读取函数的this 绑定rece…

canvas画出简陋版随鼠标转动眼睛且会眨眼的可爱樱桃小丸子

可到我的github上下载文件 需求&#xff1a; 刚加载时鼠标不移动&#xff0c;眼睛会不停地眨眼眼球会跟随鼠标移动而移动鼠标不移动时恢复眨眼效果提示&#xff1a; 除了眼睛是动态以外&#xff0c;其他静态绘制都在static()函数中利用椭圆的短轴长度先变短后恢复长度来模拟…

Windows 64 位 mysql 5.7以上版本包解压中没有data目录和my-default.ini以及服务无法启动的解决办法以及修改初始密码的方法...

LZ初学SQL&#xff0c;本来以为开源的安装很简单&#xff0c;但是中间出现了一些问题&#xff0c;记录下来&#xff0c;希望能帮助到他人。 mysql官网下载地址&#xff1a;https://dev.mysql.com/downloads/mysql/点击打开链接 以5.7.20版本为例 首先安装包解压后&#xff0c;没…

总结 构造函数与非构造函数 原型继承的一个方法

这两天真的一直在看原型以及继承之间的千丝万缕&#xff0c;哇&#xff0c;收获颇多&#xff0c;不过所谓温故知新&#xff0c;还是要多复习复习知识点&#xff0c;才能察觉那些之前不易发现的小小sparkle 真心推荐MDN文档——对象原型&#xff0c;JavaScript 中的继承&#x…

Vue学习笔记(二)—— vue项目中使用axios

一、文档链接 axios文档 vue开发插件 二、axios 简介 axios 是一个基于Promise 用于浏览器和 nodejs 的 HTTP 客户端&#xff0c;它本身具有以下特征&#xff1a; 从浏览器中创建 XMLHttpRequest 从 node.js 发出 http 请求 支持 Promise API 拦截请求和响应 转换请求和响应…

jquery对json 键值对或数组的增加、删除、遍历操作

在前端遍历json键值对或数组遍历的情况也会经常用到&#xff0c;我们知道在java、c#其它的语言里提供方便的方法来操作&#xff0c;那么在json里面有没有类似的方法呢&#xff0c;废话就不多说了上代码&#xff1a;var jsonStr{}; //增加 jsonStr["name1"]"yu&q…

廖雪峰老师Git教程代码梳理

建立版本库 创建一个版本库非常简单&#xff0c;首先&#xff0c;选择一个合适的地方&#xff0c;创建一个空目录&#xff08;repository&#xff09;&#xff1a; $ mkdir learngit //创建learngit目录 $ cd learngit //切换当前目录为learngit目录 $ pwd //用于显示当…

es6 --- Promise.catch

Promise.prototype.catch(): 是.then(null, rejection)的别名,用于指定发生错误时的回调函数 p.then( (val) -> console.log(fulfilled:, val)).catch( (err) > console.log(rejected, err));// 等同于 p.then( (val) > console.log(fulfilled:, val)).then(null, (e…

爬虫的一些工具(二)

爬虫的一些工具(二) 1. 常有的工具 (1). python(2). pycharm(3).浏览器i.chromeii.火狐(4).fiddler的使用2 fiddler的使用 (1).操作界面(2)界面含义请求(Request)部分详解名称含义Headers显示客户端发送到服务器的 HTTP 请求的,header 显示为一个分级视图&#xff0c;包含了 We…

微信开发者工具一打开代码编辑区文件全部不见了

今天开微信开发者工具时&#xff0c;一打开竟然文件全部不见了&#xff01;然后页面也编译不出来&#xff0c;搜了一下大神们的建议&#xff1a; 1、在编辑器控制台输入&#xff1a;openVendor 回车 会打开一个文件夹&#xff1a;C:\Users\Administrator\AppData\Local\微信we…

vue项目中所使用的element-UI / echarts

高清版思维导图见后台管理项目地址 1.login登录页面 < el-form >表单 在 Form 组件中&#xff0c;每一个表单域由一个 Form-Item 组件构成&#xff0c;表单域中可以放置各种类型的表单控件&#xff0c;包括 Input、Select、Checkbox、Radio、Switch、DatePicker、TimeP…

es6 --- 使用yield*命令遍历完全二叉树

首先定义二叉树的结构: // 定义二叉树的结构 function Tree(left, label, right) {this.left left;this.label label;this.right right; }// 对二叉树采用中序遍历 function* inorder(t) {if(t) {yield* inorder(t.left);yield t.label;yield* inorder(t.right);} }// 生成…

面向对象之继承与派生

阅读目录 一 初识继承二 继承与抽象&#xff08;先抽象再继承&#xff09;三 继承与重用性四 派生五 组合与重用性六 接口与归一化设计七 抽象类八 继承实现的原理&#xff08;可恶的菱形问题&#xff09;九 子类中调用父类的方法一 初识继承 什么是继承 继承是一种创建新类的方…

SpringBoot(十三)-- 不同环境下读取不同配置

一、场景&#xff1a; 在开发过程中 会使用 开发的一套数据库&#xff0c;测试的时候 又会使用测试的数据库&#xff0c;生产环境中 又会切换到生产环境中。常用的方式是 注释掉一些配置&#xff0c;然后释放一下配置。SpringBoot提供了在不同环境下切换不同配置的功能&#xf…

MDN文档基础知识搜集

Array数组&#xff0c;一种允许你存储多个值在一个引用里的结构。var myVariable [1,Bob,Steve,10]; 引用数组的元素只需&#xff1a;myVariable[0], myVariable[1], 等等. 发布工具: FTP 客户端 你还需要一种将文件从本地硬盘上传到远程Web服务器的方法。 为了做到这一点&am…

vue-cli生成项目时你应当知道的

一、安装 npm install -g vue-cli二、创建项目 vue init 模板名 项目名 vue init webpack mymall模板名: 1 . webpack 最常用 2 . webpack-simple // 一个简单webpackvue-loader的模板&#xff0c;不包含其他功能。 3 . browserify // 一个全面的Browserifyvueify 的模板&am…

es6 --- 正确获取Generator函数内部的this对象使其可以使用new

首先看2个例子 function * g() {this.a 11; }let o g(); console.log(o.a);可以看见Generator函数里面的this指向的对象取不出来. 再看下一个例子: function* F() {yield this.x 2;yield this.y 3; } new F();可以看出Generator函数无法使用new操作符, 下面一共一个解决…

mysql三-3:完整性约束

阅读目录 一 介绍二 not null与default三 unique四 primary key五 auto_increment六 foreign key七 作业一 介绍 约束条件与数据类型的宽度一样&#xff0c;都是可选参数 作用&#xff1a;用于保证数据的完整性和一致性主要分为&#xff1a; PRIMARY KEY (PK) 标识该字段为该…