{__ob__: Observer} startTime : "13:0:0" stopTime : "14:0:0"} 判断这个对象在0 : startTime : "13:0:0" stopTime : "14:0:0" __ob__ : Observer {value: {…}, shallow: false, mock: false, dep: Dep, vmCount: 0} get startTime : ƒ reactiveGetter() set startTime : ƒ reactiveSetter(newVal) get stopTime : ƒ reactiveGetter() set stopTime : ƒ reactiveSetter(newVal) [[Prototype]] : Object 1 : startTime : "16:0:0" stopTime : "17:0:0" __ob__ : Observer {value: {…}, shallow: false, mock: false, dep: Dep, vmCount: 0} get startTime : ƒ reactiveGetter() set startTime : ƒ reactiveSetter(newVal) get stopTime : ƒ reactiveGetter() set stopTime : ƒ reactiveSetter(newVal) [[Prototype]] : Object 2 : startTime : "16:0:0" stopTime : "0:0:0" __ob__ : Observer {value: {…}, shallow: false, mock: false, dep: Dep, vmCount: 0} get startTime : ƒ reactiveGetter() set startTime : ƒ reactiveSetter(newVal) get stopTime : ƒ reactiveGetter() set stopTime : ƒ reactiveSetter(newVal) [[Prototype]] : Object 3 : startTime : "16:22:58" stopTime : "19:22:58" 在这个数组中的处在第几个,代码怎么写
时间: 2023-12-14 19:37:25 浏览: 145
这个数组中的对象处于第4个位置,可以使用数组的indexOf方法来查找该对象在数组中的位置,代码如下:
```
const arr = [
{startTime: "13:0:0", stopTime: "14:0:0", __ob__: Observer},
{startTime: "16:0:0", stopTime: "17:0:0", __ob__: Observer},
{startTime: "16:0:0", stopTime: "0:0:0", __ob__: Observer},
{startTime: "16:22:58", stopTime: "19:22:58", __ob__: Observer}
];
const obj = {startTime: "16:22:58", stopTime: "19:22:58", __ob__: Observer};
const index = arr.indexOf(obj);
console.log(index); // 输出3
```
相关问题
{__ob__: Observer} startTime : "13:0:0" stopTime : "14:0:0"} 判断这个对象在0 : startTime : "13:0:0" stopTime : "14:0:0" __ob__ : Observer {value: {…}, shallow: false, mock: false, dep: Dep, vmCount: 0} get startTime : ƒ reactiveGetter() set startTime : ƒ
这个对象是一个响应式对象,它有两个属性,startTime 和 stopTime。__ob__ 是一个特殊的属性,它是 Vue.js 内部用来实现响应式的,通常我们不需要直接访问它。 startTime 和 stopTime 都有对应的 getter 和 setter 函数,这些函数在对象被访问或修改时会被触发。
要判断这个对象是否在0点到1点之间,可以先将 startTime 和 stopTime 转换成对应的时间戳,然后比较它们与0点和1点的时间戳的大小关系。具体实现可以参考下面的代码:
```javascript
// 将时间字符串转换成时间戳
function getTimeStamp(timeStr) {
const [hour, minute, second] = timeStr.split(':');
return +new Date(0, 0, 0, hour, minute, second);
}
const obj = {
startTime: '13:0:0',
stopTime: '14:0:0',
__ob__: new Observer(),
get startTime() {
return this.__ob__.value.startTime;
},
set startTime(val) {
this.__ob__.value.startTime = val;
},
get stopTime() {
return this.__ob__.value.stopTime;
},
set stopTime(val) {
this.__ob__.value.stopTime = val;
},
};
const startTimestamp = getTimeStamp(obj.startTime);
const stopTimestamp = getTimeStamp(obj.stopTime);
const zeroTimestamp = getTimeStamp('0:0:0');
const oneTimestamp = getTimeStamp('1:0:0');
if (startTimestamp >= zeroTimestamp && stopTimestamp <= oneTimestamp) {
console.log('在0点到1点之间');
} else {
console.log('不在0点到1点之间');
}
```
将[0 : {__ob__: Observer} 1 : {__ob__: Observer} 2 : {__ob__: Observer}] 处理成一个数组对象
这个数据看起来像是 Vue.js 的响应式数组对象。如果想将其处理成一个普通的数组对象,可以使用 `Array.from()` 方法或者展开运算符 `...`,示例如下:
```javascript
const originalArr = [
{__ob__: Observer},
{__ob__: Observer},
{__ob__: Observer}
];
// 使用 Array.from() 方法
const newArray1 = Array.from(originalArr);
console.log(newArray1); // [{__ob__: Observer}, {__ob__: Observer}, {__ob__: Observer}]
// 使用展开运算符 ...
const newArray2 = [...originalArr];
console.log(newArray2); // [{__ob__: Observer}, {__ob__: Observer}, {__ob__: Observer}]
```
以上两种方法都可以将响应式数组对象转换成普通的数组对象。
阅读全文