工作记录2

  1. 要实现y轴超出部分滚动的效果,可以这样写

  2. 当后端接口还没好的时候,可以自己模拟一下接口返回的数据

    export const getCommodityDetail = (id) =>
    Promise.resolve({
    id: '11111',
    name: 'xiongxinyu',
    age: 18
    })

  3. 标签可能会只有父级标签,也有可能会有父级标签和子级标签(子级标签可能有一个或多个),因为存在父级标签和子级标签的区别,所以操作上就会有所不同,这一点可以通过接口返回的层级数据来判断,如果record.parentId==0,说明它是父级,那么就让这一行多一个"新增子项"的操作。

    <template #action="{ record }">
    <TableAction :action="getActions(record)" />
    </template>
    function getActions(record) {
    let actions = [
    {
    label: '编辑',
    onClick: handleEdit.bind(null,record),
    }
    {
    label: '删除',
    popConfrim:{
    title:'是否确认删除',
    confirm: handleDelete.bind(null, record),
    }
    }
    ]
    if(record.parentId == '0') {
    actions.unshift({
    label: '新增子项',
    onClick: handleAddSub.bind(null,record)
    })
    }
    return actions;
    }

  4. 展开或折叠树形表格

<a-button @click="expandAll">展开全部</a-button>

<a-button @click="collapseAll">折叠全部</a-button>

setup(){
  const expandedRowKeys = ref<string>([]);
  const [registerTable, { expandAll, collapseAll, reload}] = useTable({
    isTreeTable: true,
    expandedRowKeys: expandedRowKeys.value,
    onExpand: (expande, record) => {
      if(expande){
        if(!expandedRowKeys.value.includes(record.id)){
          expandedRowKeys.value.push(record.id);
        }
      }else{
        let index = expandedRowKeys.value.indexOf(record.id);
        expandedRowKeys.value.splice(index,1);
      }
    }
  })
}
  1. 利用微信schema从app跳转到小程序

本来是可以前端自己去生成schemaUrl的,但是生成的链接有时效性,然后最新的那种明文码它好多设备不支持,所以最后决定让后端生成。前端把想要到时候在小程序页面拿到的参数在此时传递给后端,后端返回schemaUrl。

const res = await getwxScheme(channelId,projectId);
Linking.openURL(res)

因为生成这个链接的时候后端是拿了我们传的参数去生成的,所以返回的链接的信息里其实是携带了这些参数的,那么我们在用这个链接跳转到小程序的某个页面的时候,就可以在这个页面拿到这个参数了,就正常在onLoad里面的option拿就行。

onLoad(option){
  console.log(option.projectId,option.channelId);
}
  1. 联系在线客服

首先通过调用接口获取机构在机构端对客服的一些配置,可以选择配置客服的方式(有h5和js客服),选择配置h5客服的话,就必须得填写客服链接,选择配置js客服的话,就必须得填写JS客服代码,如果获取到接口返回的信息表示机构配置的是h5客服,那就直接用window.opend打开当时填的客服链接即可,但如果是js客服的话,就可以调用螳螂客服的一些api来实现了。

const openChatModal = async () => {
  if(customerSet.customerType == 1){
    window.open(customerSet.customerLink, "_blank");
    return;
  }else{
    chartCode();
  }
}

const chartCode = () => {
  if(window.mantis && window.mantis.requestChat) {
    window.mantis.requestChat();
  }else {
    const scriptDom = stringToDom(customerSet.customerCode);
    document.head.appendChild(scriptDom);
    // 设置轮询,避免查不到
    let num = 0;
    let timerId = setInterval(() => {
      num++;
      // 轮询10s没有初始化关闭
      if(num >20){
        clearInterval(timerId);
      }
      // 获取到requestChat
      if(window.mantis && window.mantis.requestChat) {
        window.mantis.requestChat();
        clearInterval(timerId);
      }
    },500);
  }
}
const stringToDOM = (str:string) => {
  if(str.includes("script")){
    var parser = new DOMParser();
    // 使用DOMParser的parseFromString方法来转换字符串到DOM
    var doc = parser.parseFromString(str,"text/html");
    // 获取转换后的DOM对象
    var dom: any = doc.body.firstChild || doc.head.firstChild;
    const script1:any = document.createElement("script");
    script1.src = dom.src;
    return script1;
  }else {
    const script1:any = document.createElement("script");
    script1.src = str;
    return script1;
  }
}
相关推荐
Watermelo6177 分钟前
详解js柯里化原理及用法,探究柯里化在Redux Selector 的场景模拟、构建复杂的数据流管道、优化深度嵌套函数中的精妙应用
开发语言·前端·javascript·算法·数据挖掘·数据分析·ecmascript
m0_748248949 分钟前
HTML5系列(11)-- Web 无障碍开发指南
前端·html·html5
m0_7482356120 分钟前
从零开始学前端之HTML(三)
前端·html
旭久1 小时前
SpringBoot的Thymeleaf做一个可自定义合并td的pdf表格
pdf·html·springboot
一个处女座的程序猿O(∩_∩)O2 小时前
小型 Vue 项目,该不该用 Pinia 、Vuex呢?
前端·javascript·vue.js
hackeroink5 小时前
【2024版】最新推荐好用的XSS漏洞扫描利用工具_xss扫描工具
前端·xss
迷雾漫步者7 小时前
Flutter组件————FloatingActionButton
前端·flutter·dart
向前看-7 小时前
验证码机制
前端·后端
燃先生._.8 小时前
Day-03 Vue(生命周期、生命周期钩子八个函数、工程化开发和脚手架、组件化开发、根组件、局部注册和全局注册的步骤)
前端·javascript·vue.js