uts+uniapp踩坑记录(vue3项目

杂记:

web-view方面

内嵌html使用web-view时,直接用

复制代码
uni.postMessage({
            data: {
              action: 'message'    // 你要传的信息
            }
          });

示例上写的是用

复制代码
document.addEventListener('UniAppJSBridgeReady', function() {  
    uni.postMessage({  
        data: {  
            action: 'postMessage'  
        }  
    });  
});

注意点:监听'UniAppJSBridgeReady , 有时候会失败,一直不触发,检查本地html文件放在hybrid文件夹里面,如:hybrid/html/js/xxx.js, hybrid/html/just.html

记得在html文件最上面引入uni.webview.1.5.5.js,版本要是1.5.4及以上的

最后接收的app内的onmessage函数,接收类型一定要对 ,如UniWebViewMessageEvent或者UniWebViewErrorEvent

复制代码
const handlePostMessage = (event: UniWebViewMessageEvent) => {}

uts语法方面

1.有返回值的,一定要在函数定义时定义返回值类型!

2.循环注意,有时候你直接在箭头函数定义时用as断言它的类型,写循环可能报错(有时候页不报错),比如:

arr.map((item:string)=>{})

不行改成

arr.map((item)=>{

console.log(item as string )

})

顺便放几个常用循环和计算,监听方法的示例:

计算属性:

javascript 复制代码
const showBtn = computed((): boolean => tabs.value == '1')

watch监听:

javascript 复制代码
watch(
  (): string => tabs.value as string,
  (newValue: string) => {
    if (newValue === '1') {
      const op = {
        title: '勾选',
        key: 'checkEd',
        width: '70rpx',
      } as xTableColumns
      columnsData.value.unshift(op)
    } else {
      if (columnsData.value[0]['key'] === 'checkEd') {
        columnsData.value.splice(0, 1)
      }
    }
  },
  {
    immediate: true,
    deep: true, // 开启深度监听
  },
)

filter循环:

javascript 复制代码
checkedValues.value = checkedValues.value.filter((itemTT: string): boolean => !iop.includes(itemTT))

some循环:

javascript 复制代码
  const dect = iop.some((itemTT: string): boolean => checkedValues.value.includes(itemTT))

map循环:

javascript 复制代码
let chooseFifter = chooseData.value.map((item): UTSJSONObject => {
    let op = { materialsTaskId: item['materialsTaskId'], approvalRecordId:            item['approvalRecordId'] }
    return op;
  })

forEach循环:

javascript 复制代码
 dataNow.forEach((item: UTSJSONObject) => {
        item['metarils'] = [] as Array<UTSJSONObject>
      })


 datas?.forEach((itemTs: UTSJSONObject, index: number) => {
    if (itemTs['approvalTaskId'] === soure['approvalTaskId']) {
      found = true
      removeIndex = index
    }
  })

JSON的转换:

javascript 复制代码
const ops = JSON.parse(uni.getStorageSync('loginUserInfo') as string)
let params = {}
params['userType'] = (ops as UTSJSONObject)['userType'] as string
注意点:这个语言和ts一样甚至比ts更要求类型(一错了就卡死),尤其是你用了组件库,要去看好它们组件库里面定义的各个传参类型。若不一致,可能不会报错,但你会得到一个空的数组或对象。要引入,如:
javascript 复制代码
import { xTableColumns } from '@/uni_modules/tmx-ui/interface.uts'
import { FORM_RULE, FORM_SUBMIT_RESULT } from '@/uni_modules/tmx-ui/interface.uts'

基本上出问题,十有八九是你类型定义没对或者你声明的类型和编辑器推断的不一样,或者你的类型没引入。

关于ref

因为我是vue3,对一个组件用ref这种方式获取实例的话,你需要知道这个组件的类型,如:

javascript 复制代码
​​​​​​​<z-paging-x ref="pagingX" :fixed="false" v-model="dataList" @query="queryList" show-back-to-top>
javascript 复制代码
const pagingX = ref<ZPagingXComponentPublicInstance | null>(null)

类似的还有:

javascript 复制代码
<x-form v-model="reqData" ref="formRef" :error-auto-page="false">


const formRef = ref<XFormComponentPublicInstance | null>(null)

有时候你用UTSJSONObject代替它特有类型不会报错,但是你只能得到空数组或对象。

ref定义变量时要先定义类型,在括号接默认值

注意:

你用ref后,若定义了数组对象等,你的.value去访问时 还要去as它的类型:

javascript 复制代码
 ;(pagingX.value as ZPagingXComponentPublicInstance).reload()




const datas: Array<UTSJSONObject> = chooseData.value as Array<UTSJSONObject>




 (): string => tabs.value as string,
注意:uts这个语言,不太建议你将赋值和定义类型合并一条代码。

变量的定义

你可以

javascript 复制代码
let op:string = (state.value as UTSJSONObject)['name'] as string;

等价于:

let op= (state.value as UTSJSONObject)['name'] as string;

注意点:有时候报错会很奇怪,你找不到时记得看看自己的**;**号有没有加好。有时候可以加你定义前,防止出错:

javascript 复制代码
 ;(dataList.value as Array<UTSJSONObject>)[index]['metarils'] = data['list']

any这个类型,不建议用,有很多奇奇怪怪的问题,你接收后端传来的数据时可以先用any,后面再自己拆分。

关于getXXX方法,

如:data.getArray('list') as Array<UTSJSONObject>

还有getString等等,就相当于你得到这个变量时就给他定义了类型,但我不太用这个。文档说这是更安全访问的方式。

先写道这,后面遇到了再长期更新...

相关推荐
放下华子我只抽RuiKe59 分钟前
React 从入门到生产(四):自定义 Hook
前端·javascript·人工智能·深度学习·react.js·自然语言处理·前端框架
IT_陈寒2 小时前
Redis缓存击穿把我整不会了,原来还有这手操作
前端·人工智能·后端
idcu2 小时前
深入 Lyt.js 组件系统:L2 渲染引擎层的核心
前端·typescript
这是程序猿2 小时前
Spring Boot自动配置详解
java·大数据·前端
文心快码BaiduComate2 小时前
干货|Comate Harness Engineering工程实践指南
前端·后端·程序员
还有多久拿退休金3 小时前
一张栈的图,治好你面试答不出 script 阻塞的病
前端·javascript
光辉GuangHui3 小时前
Agent Skill 也需要测试:如何搭建 Skill 评估框架
前端·后端·llm
To_OC3 小时前
我终于搞懂 Claude Code 核心逻辑!90%的人都用错了模式
前端·ai编程
蓝宝石的傻话3 小时前
Headless浏览器的隐形陷阱:为什么你的AI自动化工具抓不到页面早期错误?
前端
irving同学462383 小时前
Node 后端实战:JWT 认证与生产级错误处理
前端·后端