uni-copy.js 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. export default function uniCopy({content,success,error}) {
  2. if(!content) return error('复制的内容不能为空 !')
  3. content = typeof content === 'string' ? content : content.toString() // 复制内容,必须字符串,数字需要转换为字符串
  4. /**
  5. * 小程序端 和 app端的复制逻辑
  6. */
  7. //#ifndef H5
  8. uni.setClipboardData({
  9. data: content,
  10. success: function() {
  11. success("复制成功~")
  12. },
  13. fail:function(){
  14. success("复制失败~")
  15. }
  16. });
  17. //#endif
  18. /**
  19. * H5端的复制逻辑
  20. */
  21. // #ifdef H5
  22. if (!document.queryCommandSupported('copy')) { //为了兼容有些浏览器 queryCommandSupported 的判断
  23. // 不支持
  24. error('浏览器不支持')
  25. }
  26. let textarea = document.createElement("textarea")
  27. textarea.value = content
  28. textarea.readOnly = "readOnly"
  29. document.body.appendChild(textarea)
  30. textarea.select() // 选择对象
  31. textarea.setSelectionRange(0, content.length) //核心
  32. let result = document.execCommand("copy") // 执行浏览器复制命令
  33. if(result){
  34. success("复制成功~")
  35. }else{
  36. error("复制失败,请检查h5中调用该方法的方式,是不是用户点击的方式调用的,如果不是请改为用户点击的方式触发该方法,因为h5中安全性,不能js直接调用!")
  37. }
  38. textarea.remove()
  39. // #endif
  40. }