当前位置:   article > 正文

HarmonyOS Developer之生成二维码

HarmonyOS Developer之生成二维码

qrcode

生成并显示二维码

属性

在这里插入图片描述

样式

在这里插入图片描述

创建qrcode组件

在pages/index目录下的hml文件中创建一个qrcode组件
HTML

<!-- xxx.hml-->
<div class="container">
  <qrcode value="Hello"></qrcode>
</div>
  • 1
  • 2
  • 3
  • 4

CSS

/* xxx.css */
.container {
  width: 100%;
  height: 100%;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: #F1F3F5;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

生成效果
在这里插入图片描述

设置组件类型

通过设置qrcode的type属性来选择按钮类型,如定义qrcode为矩形二维码、圆形二维码
HTML

<!-- xxx.hml-->
<div class="container">
  <select onchange="settype">
    <option for="{{bcol_list}}" value="{{$item}}">{{$item}}</option>
  </select>
  <qrcode value="Hello" type="{{qr_type}}"></qrcode>
</div>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

CSS

/* xxx.css */
.container {
  width: 100%;
  height: 100%;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: #F1F3F5;
}
select{
  margin-top: 50px;
  margin-bottom: 50px;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

JS

// index.js
export default {
  data: {
    qr_type: 'rect',
    bcol_list: ['rect','circle']
  },
  settype(e) {
    this.qr_type = e.newValue 
  },
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

在这里插入图片描述

设置样式

通过color和background-color样式为二维码设置显示颜色和背景颜色
HTML

<!-- xxx.hml-->
<div class="container">
  <qrcode value="Hello" type="rect"></qrcode>
</div>
  • 1
  • 2
  • 3
  • 4

CSS

/* xxx.css */
.container {
  width: 100%;
  height: 100%;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: #F1F3F5;
}
qrcode{
  width: 300px;
  height: 300px;
 color: blue;  background-color: #ffffff;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

在这里插入图片描述

说明
 - width和height不一致时,取二者较小值作为二维码的边长,且最终生成的二维码居中显示。
 - width和height只设置一个时,取设置的值作为二维码的边长。都不设置时,使用200px作为默认边长。
  • 1
  • 2
  • 3

根据输入的值动态生成二维码

HTML

<!-- xxx.hml-->
<div class="container">
  <input style="margin-bottom: 100px;" onchange="change"></input>
  <qrcode value="{{textVal}}"></qrcode>
</div>
  • 1
  • 2
  • 3
  • 4
  • 5

CSS

/* xxx.css */
.container {
  width: 100%;
  height: 100%;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: #F1F3F5;
}
qrcode{
  width: 400px;
  height: 400px;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

JS

// index.js
export default{
  data: {
    textVal: ''
  },
  change(e){
    this.textVal = e.value
  }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

在这里插入图片描述

本文内容由网友自发贡献,转载请注明出处:https://www.wpsshop.cn/w/寸_铁/article/detail/998862
推荐阅读
相关标签
  

闽ICP备14008679号