当前位置:首页 > VUE

vue实现列表水印

2026-01-11 22:16:57VUE

实现列表水印的方法

在Vue中为列表添加水印可以通过多种方式实现,以下是几种常见的方法:

使用CSS背景图

通过CSS的background-image属性为列表元素添加水印背景。水印可以是文字或图片。

<template>
  <div class="watermarked-list">
    <div v-for="item in list" :key="item.id" class="list-item">
      {{ item.text }}
    </div>
  </div>
</template>

<style>
.watermarked-list {
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="200" height="200"><text x="50%" y="50%" font-size="20" fill="rgba(0,0,0,0.1)" text-anchor="middle" dominant-baseline="middle" transform="rotate(-45, 100, 100)">WATERMARK</text></svg>');
  background-repeat: repeat;
}
.list-item {
  padding: 10px;
  background-color: white;
  margin: 5px;
}
</style>

使用Canvas生成水印

动态生成水印图像并设置为背景。

<template>
  <div ref="watermarkContainer" class="watermark-container">
    <div v-for="item in list" :key="item.id" class="list-item">
      {{ item.text }}
    </div>
  </div>
</template>

<script>
export default {
  mounted() {
    this.generateWatermark();
  },
  methods: {
    generateWatermark() {
      const canvas = document.createElement('canvas');
      canvas.width = 200;
      canvas.height = 200;
      const ctx = canvas.getContext('2d');
      ctx.font = '20px Arial';
      ctx.fillStyle = 'rgba(0, 0, 0, 0.1)';
      ctx.textAlign = 'center';
      ctx.textBaseline = 'middle';
      ctx.translate(100, 100);
      ctx.rotate(-Math.PI / 4);
      ctx.fillText('WATERMARK', 0, 0);

      const url = canvas.toDataURL('image/png');
      this.$refs.watermarkContainer.style.backgroundImage = `url(${url})`;
    }
  }
}
</script>

<style>
.watermark-container {
  background-repeat: repeat;
}
.list-item {
  padding: 10px;
  background-color: white;
  margin: 5px;
}
</style>

使用伪元素添加水印

通过CSS伪元素在每个列表项上添加水印。

<template>
  <div class="list-container">
    <div v-for="item in list" :key="item.id" class="watermarked-item">
      {{ item.text }}
    </div>
  </div>
</template>

<style>
.watermarked-item {
  position: relative;
  padding: 10px;
  margin: 5px;
  background-color: white;
}
.watermarked-item::after {
  content: "WATERMARK";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  color: rgba(0, 0, 0, 0.1);
  transform: rotate(-45deg);
  pointer-events: none;
  z-index: 1;
}
</style>

使用自定义指令

创建Vue自定义指令来动态添加水印。

<template>
  <div>
    <div v-for="item in list" :key="item.id" v-watermark>
      {{ item.text }}
    </div>
  </div>
</template>

<script>
export default {
  directives: {
    watermark: {
      inserted(el) {
        const watermark = document.createElement('div');
        watermark.style.position = 'absolute';
        watermark.style.top = '0';
        watermark.style.left = '0';
        watermark.style.right = '0';
        watermark.style.bottom = '0';
        watermark.style.display = 'flex';
        watermark.style.alignItems = 'center';
        watermark.style.justifyContent = 'center';
        watermark.style.fontSize = '20px';
        watermark.style.color = 'rgba(0, 0, 0, 0.1)';
        watermark.style.transform = 'rotate(-45deg)';
        watermark.style.pointerEvents = 'none';
        watermark.style.zIndex = '1';
        watermark.textContent = 'WATERMARK';

        el.style.position = 'relative';
        el.appendChild(watermark);
      }
    }
  }
}
</script>

每种方法都有其适用场景,CSS背景图方法最简单但灵活性较低,Canvas方法可以生成更复杂的水印,伪元素方法适合单个元素的水印,自定义指令则提供了最大的灵活性和复用性。

vue实现列表水印

标签: 水印列表
分享给朋友:

相关文章

vue实现列表

vue实现列表

Vue 实现列表的方法 在 Vue 中实现列表渲染通常使用 v-for 指令,可以动态生成多个元素。以下是几种常见的实现方式: 基础列表渲染 使用 v-for 遍历数组,生成列表项。v-for 需…

vue列表查询实现

vue列表查询实现

实现 Vue 列表查询功能 基础列表渲染 在 Vue 中可以通过 v-for 指令实现列表渲染,结合计算属性动态过滤数据: <template> <div> &l…

vue实现WiFi列表

vue实现WiFi列表

获取WiFi列表的Vue实现 使用Vue获取WiFi列表需要结合浏览器API或后端服务,因为浏览器出于安全限制无法直接访问系统WiFi信息。以下是两种常见实现方式: 方法一:通过Web API获取附…

网页制作css 列表

网页制作css 列表

创建CSS列表样式 使用CSS可以自定义HTML列表(有序列表<ol>和无序列表<ul>)的外观,包括项目符号、缩进、颜色等。以下是一些常见的列表样式方法: 基础列表样式 通…

vue实现商品列表

vue实现商品列表

Vue实现商品列表的方法 使用Vue实现商品列表需要结合数据绑定、组件化和状态管理。以下是实现商品列表的几种常见方法: 基础数据绑定实现 在Vue组件中定义商品数据数组,使用v-for指令循环渲染商…