1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
| const config = require('../config');
| Component({
| options: {
| styleIsolation: 'shared'
| },
| properties: {
| data: {
| type: Object,
| value: {}
| }
| },
| data: {
| attr:{
| src:'',
| class:'',
| style:''
| },
| size:{
| w:0,
| h:0
| },
| styleObj:{}
| },
| lifetimes:{
| attached:function(){
| const _ts = this;
| let dataAttr = this.data.data.attrs;
|
| // 将图片大小处理到对象中
| if(dataAttr.width){
| _ts.data.size.w = +dataAttr.width / config.dpr;
| };
|
| if(dataAttr.height){
| _ts.data.size.h = +dataAttr.height / config.dpr;
| };
|
| // 将样式合并到样式对象中
| if(dataAttr.style){
| let re = /;\s{0,}/ig;
| dataAttr.style = dataAttr.style.replace(re,';');
| dataAttr.style.split(';').forEach(item => {
| let itemArr = item.split(':');
| if(/^(width|height)$/i.test(itemArr[0])){
| let num = parseInt(itemArr[1]) || 0,
| key = '';
| // itemArr[1] = num / config.dpr + itemArr[1].replace(num,'');
| switch (itemArr[0].toLocaleLowerCase()) {
| case 'width':
| key = 'w';
| break;
| case 'height':
| key = 'h';
| break;
| };
| _ts.data.size[key] = num / config.dpr;
| }else{
| _ts.data.styleObj[itemArr[0]] = itemArr[1];
| };
| });
| };
|
| // 设置公式图片
| _ts.setData({
| attrs:{
| src:dataAttr.src,
| class:dataAttr.class,
| style:_ts.setStyle(_ts.data.styleObj)
| },
| size:_ts.data.size
| });
| }
| },
| methods: {
| // 设置图片样式
| setStyle:function(o){
| let str = ``;
| for(let key in o){
| str += `${key}:${o[key]};`;
| };
| return str;
| },
|
| // 图片加载完成设置图片大小
| load:function(e){
| const _ts = this;
|
| if(!_ts.data.size.w || !_ts.data.size.h){
| _ts.setData({
| size:{
| w:e.detail.width / config.dpr,
| h:e.detail.height / config.dpr
| }
| });
| };
| }
| }
| })
|
|