74 lines
1.9 KiB
JavaScript
74 lines
1.9 KiB
JavaScript
|
export const tools = {
|
|||
|
methods: {
|
|||
|
//复制url
|
|||
|
copyUrl() {
|
|||
|
this.uniCopy({
|
|||
|
content: window.location.href,
|
|||
|
success: () => {
|
|||
|
uni.showToast({icon:none,title:'复制成功!'})
|
|||
|
},
|
|||
|
error: () => {
|
|||
|
uni.showToast({icon:none,title:'复制失败!'})
|
|||
|
}
|
|||
|
})
|
|||
|
},
|
|||
|
//复制内容
|
|||
|
uniCopy({content,success,error}) {
|
|||
|
content = typeof content === 'string' ? content : content.toString() // 复制内容,必须字符串,数字需要转换为字符串
|
|||
|
|
|||
|
/**
|
|||
|
* 小程序端 和 app端的复制逻辑
|
|||
|
*/
|
|||
|
//#ifndef H5
|
|||
|
uni.setClipboardData({
|
|||
|
data: content,
|
|||
|
success: function() {
|
|||
|
success("复制成功~")
|
|||
|
},
|
|||
|
fail: function() {
|
|||
|
error("复制失败~")
|
|||
|
}
|
|||
|
});
|
|||
|
//#endif
|
|||
|
|
|||
|
/**
|
|||
|
* H5端的复制逻辑
|
|||
|
*/
|
|||
|
// #ifdef H5
|
|||
|
if (!document.queryCommandSupported('copy')) { //为了兼容有些浏览器 queryCommandSupported 的判断
|
|||
|
// 不支持
|
|||
|
error('浏览器不支持')
|
|||
|
}
|
|||
|
let textarea = document.createElement("textarea")
|
|||
|
textarea.value = content
|
|||
|
textarea.readOnly = "readOnly"
|
|||
|
document.body.appendChild(textarea)
|
|||
|
textarea.select() // 选择对象
|
|||
|
textarea.setSelectionRange(0, content.length) //核心
|
|||
|
let result = document.execCommand("copy") // 执行浏览器复制命令
|
|||
|
if (result) {
|
|||
|
success("复制成功~")
|
|||
|
} else {
|
|||
|
error("复制失败,请检查h5中调用该方法的方式,是不是用户点击的方式调用的,如果不是请改为用户点击的方式触发该方法,因为h5中安全性,不能js直接调用!")
|
|||
|
}
|
|||
|
textarea.remove()
|
|||
|
// #endif
|
|||
|
},
|
|||
|
//预览图片
|
|||
|
lookImage(index, imagesList) {
|
|||
|
uni.previewImage({
|
|||
|
current: index,
|
|||
|
urls: imagesList,
|
|||
|
longPressActions: {
|
|||
|
itemList: ['发送给朋友', '保存图片', '收藏'],
|
|||
|
success: function(data) {
|
|||
|
console.log(data)
|
|||
|
},
|
|||
|
fail: function(err) {
|
|||
|
console.log(err.errMsg);
|
|||
|
}
|
|||
|
}
|
|||
|
});
|
|||
|
},
|
|||
|
}
|
|||
|
}
|