const cloud = require('wx-server-sdk') cloud.init({ env: cloud.DYNAMIC_CURRENT_ENV }) const db = cloud.database() const _ = db.command const col = db.collection('usersproducts') // 云函数入口函数 exports.main = async (event, context) => { console.log(event) let ps let query = {} if (event.query.searchInput && event.query.type) { query = _.and([ { type: event.query.type, _openid: event.usersID }, _.or([ { namea: db.RegExp({ regexp: event.query.searchInput, options: 'i', }) }, { nameb: db.RegExp({ regexp: event.query.searchInput, options: 'i', }) }, { carmodelname: db.RegExp({ regexp: event.query.searchInput, options: 'i', }) } ]) ]) } else if(event.query.searchInput && !event.query.type){ query = _.and([ { _openid: event.usersID }, _.or([ { namea: db.RegExp({ regexp: event.query.searchInput, options: 'i', }) }, { nameb: db.RegExp({ regexp: event.query.searchInput, options: 'i', }) }, { carmodelname: db.RegExp({ regexp: event.query.searchInput, options: 'i', }) } ]) ]) } else if(!event.query.searchInput && event.query.type){ query = _.and([ { type: event.query.type, _openid: event.usersID }, ]) } else { query = {_openid: event.usersID} } const res = await col.where(query) .orderBy('lastTime', 'desc') .skip(event.length) .limit(event.limit) .get() const ps = res.data console.log(ps) return ps }请你优化这个微信云函数,并把优化好的代码发给我
时间: 2024-02-01 10:17:08 浏览: 79
好的,以下是优化后的代码:
```
const cloud = require('wx-server-sdk')
cloud.init({ env: cloud.DYNAMIC_CURRENT_ENV })
const db = cloud.database()
const col = db.collection('usersproducts')
exports.main = async (event, context) => {
console.log(event)
let query = {
_openid: event.usersID
}
if (event.query.searchInput) {
const reg = db.RegExp({
regexp: event.query.searchInput,
options: 'i'
})
query = {
...query,
$or: [
{ namea: reg },
{ nameb: reg },
{ carmodelname: reg }
]
}
}
if (event.query.type) {
query = {
...query,
type: event.query.type
}
}
const res = await col.where(query)
.orderBy('lastTime', 'desc')
.skip(event.length)
.limit(event.limit)
.get()
const ps = res.data
console.log(ps)
return ps
}
```
这里的主要优化点是:
1. 代码逻辑更清晰易懂,将各种情况分开处理,并使用对象的解构和属性展开语法来简化代码。
2. 对搜索关键词进行正则表达式的编译,避免了每次查询都需要编译一次的性能损失。
3. 使用 `$or` 操作符来简化多个字段的匹配条件。
阅读全文