当前位置: 首页 > news >正文

uniapp 开发app使用renderjs操作dom

需求:把页面中的对话内容另存为一张图片保存到手机相册。
解决方案:这时我们需要使用到document对象创建一个dom对象计算对话内容的宽高、位置等,再利用canvas能力将内容绘制绘制成一张图保存。
现状:总所周知,非H5端,不能使用浏览器自带对象,比如document、window、localstorage、cookie等,更不能使用jquery等依赖这些浏览器对象的框架。
uniapp解决方案:uniapp文档提示到App端若要使用操作window、document的库,需要通过renderjs来实现。

首先uniapp是不支持vue3的setup语法糖的,所以获取到图片后保存到相册逻辑需要这样写:

<script>
export default defineComponent({setup(props, context) {const saveImg = async (url) => {uni.saveImageToPhotosAlbum({filePath:url,success: (res) => {console.log("保存图片成功");},fail: (err) => {console.log("保存图片失敗");}});};return {saveImg};}
});
</script>

视图层中的保存按钮:

<template><view class="save" @click="sharechat.generateImage">{{ t("share") }}</view>		
</template>

renderjs生成图片:

<script module="sharechat" lang="renderjs">  // sharechat和视图层调用的一致
export default {data(){return { }},computed: {},methods: {generateImage(event, ownerInstance) {// 计算内容宽高,位置// canvas dom生成图片// 利用uinapp保存图片到相册ownerInstance.callMethod('saveImg', url)}},mounted(){}
}
</script>

此致,就完成了所有的功能了。

http://www.lryc.cn/news/408737.html

相关文章:

  • 【面试题】MySQL `EXPLAIN`的`Extra`字段:深入解析查询优化的隐藏信息
  • Jenkins持续部署
  • 橙单前端项目下载编译遇到的问题与解决
  • 在android中怎么处理后端返回列表中包含图片id,如何将列表中的图片id转化成url
  • IM聊天代码
  • 【Go - context 速览,场景与用法】
  • Linus: vim编辑器的使用,快捷键及配置等周边知识详解
  • 数仓作业延时告警-基于关键路径预推
  • 秋招复习笔记——八股文部分:网络TCP
  • 麒麟桌面操作系统上配置Samba
  • 【Go】探索 Go 语言的内建函数 copy
  • 【React】JSX:从基础语法到高级用法的深入解析
  • JMeter 使用
  • 20240724----安装git和配置git的环境变量/如何用命令git项目到本地idea
  • JavaScript实战 - 用Canvas画一个心形
  • vim gcc
  • Symfony 表单构建器:创建和管理表单的最佳实践
  • Intel电脑CPU的选择
  • MySQL字段设置的varchar长度小于数据长度自动截取丢弃超出的长度而不是报错?
  • Linux|多线程(三)
  • 智能合约中如何返回mapping
  • nginx的学习(二):负载均衡和动静分离
  • 普中51单片机:DS1302时钟芯片讲解与应用(十)
  • Preact:轻量级替代React的选择
  • 全栈嵌入式C++、STM32、Modbus、FreeRTOS和MQTT协议:工业物联网(IIoT)可视化系统设计思路(附部分代码解析)
  • Greenplum数据库中的数据倾斜问题及处理方法
  • 缓存设计理论
  • IDEA-安装插件 驼峰下划线转换
  • 乾坤: 微前端项目切换时样式闪动(从无样式变为正常样式需要等 css chunk 文件加载完成, 加载延时受网速影响)
  • 《电子元器件之固态电容》