合同小程序前端代码仓库
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

178 lines
4.1 KiB

<!DOCTYPE html>
<html lang="zh">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>lime-svg</title>
<style>
html,
body,
img,
div {
padding: 0;
margin: 0;
width: 100%;
height: 100%;
position: relative;
overflow: hidden;
pointer-events: none;
}
html,
body {
background-color: transparent;
}
#lime-icon {
transition: all 100ms;
}
#lime-icon.is-inherit {
-webkit-mask-image: var(--svg);
mask-image: var(--svg);
-webkit-mask-repeat: no-repeat;
mask-repeat: no-repeat;
-webkit-mask-size: 100% 100%;
mask-size: 100% 100%;
background-color: var(--color, transparent);
/* 设置背景颜色为--color的值,默认为透明 */
/* background-blend-mode: multiply; */
}
#lime-icon:not(.is-inherit) {
background: var(--svg) no-repeat;
background-size: 100% 100%;
background-color: transparent;
}
#lime-image {
mix-blend-mode: lighten;
}
</style>
</head>
<body>
<div id="lime-icon">
<img id="lime-image" />
</div>
<script type="text/javascript" src="uni.webview.1.5.5.js"></script>
<script>
const image = document.getElementById('lime-image');
const icon = document.getElementById('lime-icon');
let lastSrc = ''
function setSrc(src) {
if (lastSrc == src) return
lastSrc = src;
const _src = src.split('<svg')
if (_src.length > 1) {
src = (_src[0] == '' ? 'data:image/svg+xml,' : _src[0]) + encodeURIComponent('<svg' + _src[1])
}
// src = src.replace(/#/g, '%23').replace(/"/g, `'`)
image.src = src
// icon.style.setProperty('--svg', `url('${src}')`);
icon.style.setProperty('--svg', `url("${src}")`);
// icon.style.setProperty('--svg', `url(${src})`);
image.onload = (e) => {
emit('load', {
type: "load",
timeStamp: e.timeStamp,
detail: {
width: image.naturalWidth,
height: image.naturalHeight,
}
})
}
image.onerror = (e) => {
emit('error', {
type: "error",
timeStamp: e.timeStamp,
detail: {
width: image.naturalWidth,
height: image.naturalHeight,
}
})
}
}
function setStyle(style) {
if (typeof style === 'object') {
for (let [key, value] of Object.entries(style)) {
if (key == '--color') {
if (value) {
icon.classList.add('is-inherit')
} else {
value = 'black'
}
}
icon.style.setProperty(key, value);
}
}
}
function emit(event, data = {}) {
postMessage({
event,
data
});
};
function postMessage(data) {
uni.webView.postMessage({data})
// if (window.__uniapp_x_) {
// window.__uniapp_x_.postMessage(JSON.stringify(data))
// } else if (uni.webView.postMessage) {
// uni.webView.postMessage({
// data
// })
// }
};
// setStyle({
// color: 'red',
// })
// setSrc('https://api.iconify.design/bi/bell-fill.svg')
// 禁用所有事件
document.addEventListener('mousedown', function(event) {
event.stopImmediatePropagation();
event.preventDefault();
event.stopPropagation();
});
document.addEventListener('mouseup', function(event) {
event.stopImmediatePropagation();
event.preventDefault();
event.stopPropagation();
});
document.addEventListener('click', function(event) {
event.stopImmediatePropagation();
event.preventDefault();
event.stopPropagation();
emit('click')
});
document.addEventListener('keydown', function(event) {
event.stopImmediatePropagation();
event.preventDefault();
event.stopPropagation();
});
document.addEventListener('keyup', function(event) {
event.stopImmediatePropagation();
event.preventDefault();
event.stopPropagation();
});
document.addEventListener('keypress', function(event) {
event.stopImmediatePropagation();
event.preventDefault();
event.stopPropagation();
});
</script>
</body>
</html>