其他分享
首页 > 其他分享> > vue近期遇到的问题

vue近期遇到的问题

作者:互联网

1.给接口请求的数组对象 增加自己需要的字段

const r1 = await getPaperOptionList({
  id: route.query.evaluateId,
  questionNum:
    ruleData.value[index].ruleDetail.firstScope[0].firstVal,
})
ruleData.value[index].ruleDetail.secondScope[0].paperOption =
  r1.result.map((item) => ({
    ...item,
    selectOption:
      item.type === 1 //选择题 是选项code
        ? item.code
        : item.optionsType === '1' //填空题如果是学院或专业的id,普通填空题传选项id(optionsType0.不是填空 1.学院表 2.专业表)
        ? item.id
        : item.id,
    showLabel: item.type === 1 ? item.code : item.content,
  }))

删除自定义在数组里使用的字段的属性和属性值

ruleForm.value.materialList.map((item) => {
  delete item.id
})
``
写法二:
```js
let obj = JSON.parse(JSON.stringify(this.formS))
for (let key in obj) {
  if (
    Object.prototype.hasOwnProperty.call(obj, key) &&
    key === 'checkPass'
  )
    delete obj[key]
}

2.element-plus 表格树
<el-table
    v-loading="listLoading"
    :data="tableData"
    row-key="evaluateId"
    style="width: 100%"
    :tree-props="{ children: 'children', hasChildren: 'hasChildren' }"
  >
    <el-table-column label="测评类型" prop="evaluateId" show-overflow-tooltip>
      <template #default="{ row }">
        <!-- <span>{{ evaluationFormat(row.evaluateType) }}</span> -->
        <span>{{ row.name }}</span>
      </template>
    </el-table-column>
    <el-table-column
      label="参与测试人数"
      prop="evaluateNum"
      show-overflow-tooltip
    />
    <el-table-column
      label="完成测试人数"
      prop="finishNum"
      show-overflow-tooltip
    />
</el-table>

row-key="evaluateId"是接口中唯一标准的字段

[
    {
        "children": [
            {
                "evaluateId": "1432901567562641449",
                "evaluateNum": 90,
                "evaluateType": 105,
                "finishNum": 57,
                "name": "学科知识能力"
            },
            {
                "evaluateId": "1432901567562641450",
                "evaluateNum": 37,
                "evaluateType": 107,
                "finishNum": 31,
                "name": "核心通用能力高级测试"
            }
        ],
        "evaluateId": "1432901567562641448",
        "evaluateNum": 92,
        "evaluateType": 102,
        "finishNum": 26,
        "name": "高阶能力测评"
    },
    {
        "children": [
            {
                "evaluateId": "1432901567562641452",
                "evaluateNum": 53,
                "evaluateType": 111,
                "finishNum": 50,
                "name": "适配职业测评"
            }
        ],
        "evaluateId": "1432901567562641451",
        "evaluateNum": 53,
        "evaluateType": 104,
        "finishNum": 50,
        "name": "适配职业测评"
    }
]

3.格式化数字格式 为:88,000

const numFormat = (val) => {
  //每个三位价格逗号
  var int = val.toString().split('').reverse().join('') // 翻转整数
  var temp = '' // 临时变量
  for (var i = 0; i < int.length; i++) {
    temp += int[i]
    if ((i + 1) % 3 === 0 && i !== int.length - 1) {
      temp += ',' // 每隔三个数字拼接一个逗号
    }
  }
  temp = temp.split('').reverse().join('') // 加完逗号之后翻转

  return temp // 返回
}

在这里插入图片描述


4.element-plus 上传图片 问题:上传一张图片 出现多个上传的位置 闪动 解决:上传图片 src为本地字节流地址,不然他会读多个上传到服务器的地址进行展示出现闪动效果
<el-form-item label="测评图片" prop="img">
	<el-upload
	  ref="upload"
	  action="#"
	  class="upload-test"
	  :class="{ hide: hideUpload }"
	  :file-list="imageList"
	  :http-request="uploadFile"
	  :limit="1"
	  list-type="picture-card"
	  :on-change="handleChange"
	>
	  <template #default>
	    <i class="el-icon-plus"></i>
	  </template>
	  <template #file="{ file }">
	    <div>
	      <img
	        alt=""
	        class="el-upload-list__item-thumbnail"
	        :src="file.url"
	        style="width: 146px; height: 146px; border-radius: 6px"
	      />
	      <span class="el-upload-list__item-actions">
	        <span
	          class="el-upload-list__item-delete"
	          @click="handleRemove(file)"
	        >
	          <i class="el-icon-delete"></i>
	        </span>
	      </span>
	    </div>
	  </template>
	</el-upload>
</el-form-item>

<script>
  import { ref, onActivated, onUnmounted, computed, nextTick } from 'vue'
  import { uploadPublicToAliOSS } from '@/api/common.js'
  import { ossFilePath } from '@/utils/ossFilePath'
  export default {
    name: 'ConfigureInformationModal',
    components: { WmTinymce },
    emits: ['onEmitSubmit'],
    setup() {
      const ruleForm = ref({
        img: '', //图片
      })
      const isCircle = ref(false)
      const coverMapUrl = ref('')
      const formRef = ref(null)
      const imageList = ref([])
      const upload = ref(null)
      const hideUpload = ref(false) //上传一张之后隐藏长传图片按钮

      onActivated(() => {
        loading.value = true
        formRef.value.resetFields() //初始化Form表单
        ruleForm.value = {
          type: '', //测评类型 大1 小2
          evaluateType: '', // 测评类型
          pid: '', //上级id(小测评必填)
          questionPaperId: '', //试卷id(小测评必填)
          initSize: '', //测评人数
          img: '', //图片
          intro: '', //简介
          detailIntro: '', //详细介绍
          notes: '', //测评须知
          superiority: '', //superiority
        }
        imageList.value = []
        coverMapUrl.value = ''
        hideUpload.value = false
      })
     
      // 图片上传成功回调
      const uploadFile = (data) => {
        let fd = new FormData()
        fd.append('file', data.file)
        fd.append('ossFilePath', ossFilePath('我的能量'))
        uploadPublicToAliOSS(fd).then((response) => {
          if (parseInt(response.status) === 200) {
            // console.log('imageList.value:', imageList.value)
            ruleForm.value.img = response.result.url
            isCircle.value = false
            coverMapUrl.value = response.result.url

            hideUpload.value = true
          } else {
            gp.$baseMessage(`上传失败!`, 'error')
          }
        })
      }
      // 上传文件列表删除
      const handleRemove = (file) => {
        ruleForm.value.img = ''
        coverMapUrl.value = ''
        imageList.value.splice(0, 1)
        hideUpload.value = imageList.value.length >= 1
        upload.value.handleRemove(file)
      }
      const handleChange = () => {
        //一张时 class为true
        hideUpload.value = imageList.value.length >= 1
      }

      // 编辑回显
      const fetchData = async () => {
        loading.value = true
        try {
          const res = await getTestDetail(route.query.id)
          if (res.status === 200) {
            ruleForm.value = res.result
            if (ruleForm.value.img) {
              imageList.value.push({
                url: ruleForm.value.img,
              })
              coverMapUrl.value = ruleForm.value.img
              hideUpload.value = true //回显有一张图片 隐藏class 为true
            } else {
              imageList.value = []
            }
            loading.value = false
            return Promise.resolve(true)
          }
        } catch (err) {
          return Promise.reject(err)
        }
      }
      return {
        ruleForm,
        uploadFile,
        isCircle,
        coverMapUrl,
        formRef,
        fetchData, //回显
        handleRemove,
        handleChange,
        imageList,
        upload,
        hideUpload,
      }
    },
  }
</script>
<style lang="scss" scoped>
  :deep() {
    .hide .el-upload--picture-card {
      display: none !important;
    }
  }
</style>

展示效果:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


6.移除数组指定的一组数据
ruleDetails.value.splice(index, 1)

7.预览图片element组件修改

<el-table-column align="left" label="" min-width="140">
  <template #default="scope">
    <el-row v-if="scope.row.tableDataImage" :gutter="20">
      <el-col
        v-for="(item, index) in scope.row.tableDataImage"
        :key="index"
        :span="8"
      >
        <div class="" style="margin-bottom: 6px">
          <el-image
            :ref="
              (el) => {
                if (el) test[scope.row.id] = el
              }
            "
            append-to-body
            class="show_image"
            fit="fill"
            lazy
            :preview-src-list="scope.row.images"
            :src="item"
            :z-index="9999999"
          />
        </div>
      </el-col>
      <!--  @click="getImageNumber(scope.row)" -->
      <el-button
        v-show="scope.row.tableDataImage.length < scope.row.images.length"
        class="el-button-text--primary"
        type="text"
        @click="isImagePreView(scope.row.id)"
      >
        查看更多
      </el-button>
    </el-row>
  </template>
</el-table-column>

<script>
setup() {
      const test = reactive({})
      const showViewer = ref(false)
      const getDetail = async (cursor) => {
        if (cursor) {
          info.value = { ...info.value, cursor: cursor } // 根据传递的cursor来重置pageInfo
        }
        await getPostsMsg(route.query.id, {
          cursor: cursor,
          limit: info.value.limit,
          searchCount: true,
          sidx: '',
          sord: '',
          content: info.value.content,
          // content: '',
        }).then((res) => {
          totalNum.value = res.result.total
          tableData.value = res.result.records.map((item) => {
            test[item.id] = null
            return {
              ...item,
              tableDataImage: item.images.slice(0, 3), //展示前三章图片
              copyTableDataImage: item.images.slice(0, 3), // 拷贝数据 静态 三张
              clickBtnNum: 0, //点击查看更多次数
            }
          })
          imageList.value = tableData.value.images
          const images = [...document.getElementsByTagName('img')].map((img) =>
            img.getAttribute('src')
          )
          if (images && images.length) {
            setTimeout(() => {
              loading.value = false
            }, 400)
          }
        })
      }
      const isImagePreView = (id) => {
        test[id].showViewer = true
      }
      return {
        tableData, //表格数据
        imageList,
        staticUserImage,
        getDetail, //刷新帖子列表
        getImageNumber, //查看更多
        showViewer,
        test,
        isImagePreView,
      }
    },
</script>

标签:vue,const,img,遇到,value,item,近期,imageList,id
来源: https://blog.csdn.net/weixin_41056807/article/details/121250238