Blame view

uni_modules/uview-plus/components/u-icon/util.js 2.17 KB
a2702f6d   刘淇   巡查计划
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
  import config from '../../libs/config/config';
  
  let params = {
      loaded: false
  };
  // 加载字体方法
  const loadFont = () => {
      // console.log('加载字体图标');
      // 全局加载不稳定,默认关闭,需要开启可以配置loadFontOnce。
      if (config.loadFontOnce) {
          params.loaded = true;
      }
      // #ifdef APP-NVUE
      // nvue通过weex的dom模块引入字体,相关文档地址如下:
      // https://weex.apache.org/zh/docs/modules/dom.html#addrule
      const domModule = weex.requireModule('dom');
      domModule.addRule('fontFace', {
          'fontFamily': "uicon-iconfont",
          'src': `url('${config.iconUrl}')`
      });
      if (config.customIcon.family) {
          domModule.addRule('fontFace', {
              'fontFamily': config.customIcon.family,
              'src': `url('${config.customIcon.url}')`
          });
      }
      // #endif
      // #ifdef APP || H5 || MP-WEIXIN || MP-ALIPAY
      uni.loadFontFace({
          global: true, // 是否全局生效。微信小程序 '2.10.0'起支持全局生效,需在 app.vue 中调用。
          family: 'uicon-iconfont',
          source: 'url("' + config.iconUrl + '")',
          success() {
              // console.log('内置字体图标加载成功');
          },
          fail() {
              // console.error('内置字体图标加载出错');
          }
      });
      if (config.customIcon.family) {
          uni.loadFontFace({
              global: true, // 是否全局生效。微信小程序 '2.10.0'起支持全局生效,需在 app.vue 中调用。
              family: config.customIcon.family,
              source: 'url("' + config.customIcon.url + '")',
              success() {
                  // console.log('扩展字体图标加载成功');
              },
              fail() {
                  // console.error('扩展字体图标加载出错');
              }
          });
      }
      // #endif
      // #ifdef APP-NVUE
      // if (this.customFontFamily) {
      //     domModule.addRule('fontFace', {
      //         'fontFamily': `${this.customPrefix}-${this.customFontFamily}`,
      //         'src': `url('${this.customFontUrl}')`
      //     })
      // }
      // #endif
      return true;
  };
  
  export default {
      params: params,
      loadFont
  }