壁纸小程序Vu3(预览页面:弹窗)

1.展示跳转后的分类列表图片

classlist.vue

 

<template>
  <view class="classlist">
      <view class="content">
            <navigator class="item" v-for="item in 10">
                <image src="../../common/images/64.png" mode="aspectFill"></image>
            </navigator>
      </view>
  </view>
</template>

<script setup>
 
</script>

<style lang="scss" scoped>
  
.classlist{
  .content{
    //网格布局
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap:5rpx;
    padding: 5rpx;
    .item{
      height: 440rpx;
      
      image{
        width: 100%;
        height: 100%;
        display: block;
      }
    }
    
  }
}
  
</style>

2.预览页面(preview.vue)

1)基础布局

<template>
  <view class="preview">
    
     <swiper circular>
        <swiper-item v-for="item in 4">
            <image @click="maskChange" src="../../static/images/2.jpg" mode="aspectFill"></image>
        </swiper-item>
        <swiper-item>
            <image src="../../static/images/1.jpeg" mode="aspectFill"></image>
        </swiper-item>
      </swiper>
      
      <view class="mask" v-if="maskState">
          <view class="goBack"></view>
          <view class="count">3 / 9</view>
          <view class="time">
              <uni-dateformat :date="new Date()" format="hh:mm"></uni-dateformat>
          </view>
          <view class="date">
              <uni-dateformat :date="new Date()" format="MM月dd日"></uni-dateformat>
          </view>
          
          <view class="footer">
              <view class="box">
                  <uni-icons type="info" size="28"></uni-icons>
                  <view class="text">信息</view>
              </view>
              
              <view class="box">
                  <uni-icons type="star" size="28"></uni-icons>
                  <view class="text">5分</view>
              </view>
              
              <view class="box">
                  <uni-icons type="download" size="23"></uni-icons>
                  <view class="text">下载</view>
              </view>
          </view>
          
      </view>
      
      

  </view>
</template>

<script setup>
import { ref } from 'vue';
//遮盖层
const maskState = ref(false)
const maskChange = ()=>{
   maskState.value = !maskState.value
}

  
</script>

<style lang="scss" > 

.preview{
  width: 100%;
    height: 100vh;
    swiper{
      width: 100%;
      height: 100%;
      image{
        width: 100%;
        height: 100%;
      }
    }
    .mask{
      //&>view:紧邻的子元素
      //公用的
      &>view{
        position: absolute;
        left: 0;
        margin: auto;
        color: #fff;
        right: 0;
        //内容多大就有多宽=>自动扩宽
        width: fit-content;
      }
      .goBack{
        
      }
      .count{
        position: absolute;
        top: 10vh;
        background: rgba(0, 0, 0, 0.3);
        font-size: 28rpx;
        border-radius: 40rpx;
        padding: 8rpx 28rpx;
        //模糊效果
        backdrop-filter: blur(10rpx);
      }
      .time{
        font-size: 140rpx;
        top: calc(10vh + 80rpx);
        font-weight: 100;
        line-height: 1em;
        //文字阴影
        text-shadow: 0 4rpx rgba(0, 0, 0, 0.3);
      }
      .date{
        font-size: 34rpx;
        top: calc(10vh + 240rpx);
        text-shadow: 0 4rpx rgba(0, 0, 0, 0.3);
      }
      .footer{
        background: rgba(255, 255, 255, 0.8);
        bottom: 10vh;
        width: 65vw;
        height: 120rpx;
        border-radius: 120rpx;
        color: #000;
        display: flex;
        //平均分配
        justify-content: space-around;
        //正中间
        align-items: center;
        //避免背景白色时看不到区域
        box-shadow: 0 2rpx 0 rgba(0, 0, 0, 0.1);
        backdrop-filter: blur(20rpx);
        .box{
          display: flex;
          flex-direction: column;
          align-items: center;
          justify-content: center;
          //增加触碰区域
          padding: 2rpx 12rpx;
          .text{
            font-size: 26rpx;
            color: $text-font-color-2;
          }
        }
      }
    }
    
    
}

</style>

显示时间的组件

<view class="time">
              <uni-dateformat :date="new Date()" format="hh:mm"></uni-dateformat>
          </view>

 .mask{
      //&>view:紧邻的子元素
      //公用的
      &>view{
        position: absolute;
        left: 0;
        margin: auto;
        color: #fff;
        right: 0;
        //内容多大就有多宽=>自动扩宽
        width: fit-content;
      }

top: calc(10vh + 240rpx);是一种CSS样式声明,用于设置元素的垂直位置。

3.弹窗的设置

1).壁纸信息弹窗

<!-- 弹框 -->
      <uni-popup ref="infoPopup" type="bottom">
          <view class="infoPopup">
              <view class="popHeader">
                  <view></view>
                  <view class="title">壁纸信息</view>
                  <view class="close" @click="clickInfoClose">
                    <uni-icons type="closeempty" size="18" color="#999" ></uni-icons>
                  </view>
              </view>
              <!-- scroll-view限制最大区域 -->
              <scroll-view scroll-y>
                  <view class="content">
                      <view class="row" >
                        <view class="label">壁纸ID: </view>
                        <text selectable class="value">112124124sfgd</text>
                      </view>
                   <view class="row">
                    <view class="label">分类:</view>
                    <text class="value class">明星美女</text>
                  </view>
                  <view class="row">
                    <view class="label">发布者:</view>
                    <text class="value">君泺</text>
                  </view>
                  <view class="row">
                    <text class="label">评分:</text>
                    <view class='value roteBox' >
                      <uni-rate readonly touchable value="3.5" size="16"/>
                      <text class="score">5分</text>
                    </view>
                  </view>
                  <view class="row">
                    <text class="label">摘要:</text>
                    <view class='value'>
                      摘要文字内容填充部分,摘要文字内容填充部分,摘要文字内容填充部分,摘要文字内容填充部分。
                    </view>
                  </view>
                  <view class="row">
                    <text class="label">标签:</text>
                    <view class='value tabs'>
                      <view class="tab" v-for="item in 3">标签名</view>
                    </view>
                  </view>	   
                  <view class="copyright">声明:本图片来用户投稿,非商业使用,用于免费学习交流,
                  如侵犯了您的权益,您可以拷贝壁纸ID举报至平台,邮箱513894357@qq.com,管理将删除侵权壁纸,维护您的权益。</view>
                  </view>
              </scroll-view>
          </view>
            
      </uni-popup>

 


<script setup>
import { ref } from 'vue';
//遮盖层
const maskState = ref(true)
const infoPopup = ref(null)

//点击info弹窗
const clickInfo = ()=>{
    infoPopup.value.open();
}

//点击关闭信息弹窗
const clickInfoClose = ()=>{
  infoPopup.value.close();
}

const maskChange = ()=>{
   maskState.value = !maskState.value
}
</script>
 

2)评分弹窗

 preview.vue

  <!-- :is-mask-click="false":点击×才能进行关闭,点击空白不关闭 -->
      <uni-popup ref="scorePopup" :is-mask-click="false">
        <view class="scorePopup">
            <view class="popHeader">
                <view></view>
                <view class="title" >壁纸评分</view>
                <view class="close" @click="clickScoreClose">
                  <uni-icons type="closeempty" size="18" color="#999" ></uni-icons>
                </view>
            </view>
            
            <view class="content">
              <!-- allowHalf:0.5分 -->
                <uni-rate v-model="userScore" allowHalf></uni-rate>
                <text class="text">{{userScore}}分</text>
            </view>
          
            <view class="footer">
              <!-- :disabled="!userScore" 只有进行评分时才生效 -->
              <button @click="submitScore"  :disabled="!userScore" type="default"    size="mini" plain>确认评分</button>
            </view>
          
        </view>
      </uni-popup>


<script setup>
import { ref } from 'vue';
//遮盖层
const maskState = ref(true)
const infoPopup = ref(null)
const scorePopup = ref(null)
const userScore = ref(0)
//点击info弹窗
const clickInfo = ()=>{
    infoPopup.value.open();
}
//点击关闭信息弹窗
const clickInfoClose = ()=>{
  infoPopup.value.close();
}
//评分弹窗
const clickScore = () =>{
  scorePopup.value.open();

}
//关闭
const clickScoreClose =  ()=>{
  scorePopup.value.close();

}
const maskChange = ()=>{
   maskState.value = !maskState.value
}

//确认评分
const submitScore = () =>{
  console.log("评分了");
}
</script>

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/522259.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

进口非洲鲜花为春节增姿添彩

发布时间&#xff1a;2023-01-16 文章来源&#xff1a;海关总署 图为&#xff1a;关员对进口鲜花实施查验作业 1月12日上午&#xff0c;3000枝产自肯尼亚的鲜花搭乘“内罗毕-长沙”CZ6044航班抵达长沙机场口岸。该批鲜花全部为玫瑰&#xff0c;包括花园玫瑰、奥斯…

Linux网卡IP地址配置错误的影响

在Linux系统中&#xff0c;网络配置是保持系统顺畅运行的关键一环。正确配置网卡的IP地址对于确保网络通信的准确性和效率至关重要。然而&#xff0c;如果在这个过程中发生错误&#xff0c;可能会带来一系列问题。让我们一起探讨一下&#xff0c;如果Linux网卡的IP地址配置错误…

RocketMQ的简单使用

这里需要创建2.x版本的springboot项目 导入依赖 <dependencies><dependency><groupId>org.apache.rocketmq</groupId><artifactId>rocketmq-spring-boot-starter</artifactId><version>2.2.3</version></dependency>&…

ChromeOS 中自启动 Fcitx5 和托盘 stalonetray

ChromeOS 更新的飞快&#xff0c;旧文章的方法也老是不好用&#xff0c;找遍了也没找到很好的可以开机自启动 Linux VM 和输入法、托盘的方法。 研究了一下&#xff08;不&#xff0c;是很久&#xff09;&#xff0c;终于找到个丑陋的实现。 方法基于 ChromeOS 123.0.6312.94…

带刻度透明PFA量筒耐强酸碱耐高温全氟烷氧基树脂量具

PFA量筒为上下等粗的直筒状&#xff0c;特氟龙量杯是上大下小的圆台形&#xff0c;底座均有宽台设计&#xff0c;保证稳定性&#xff0c;两者均可在实验室中作为定量量取液体的量具&#xff0c;上沿一侧有弧嘴设计&#xff0c;便于流畅地倾倒液体。 规格参考&#xff1a;5ml、…

蓝桥杯每日一题:公约数(gcd)

题目描述&#xff1a; 给定两个正整数 a 和 b。 你需要回答 q 个询问。 每个询问给定两个整数 l,r&#xff0c;你需要找到最大的整数 x&#xff0c;满足&#xff1a; x 是 a和 b 的公约数。l≤x≤r。 输入格式 第一行包含两个整数 a,b。 第二行包含一个整数 q。 接下来…

理解Go语言中的并发和并行

即使有多年的并发编程经验,有些开发人员也可能无法清楚地理解并发(concurrency)和并行(parallelism)之间的区别。下面我们以一个真实的例子来说明:一家咖啡店。 在这家咖啡店中,一名服务员负责接收订单并使用一台咖啡机进行准备。顾客下订单,然后等待他们的咖啡。 …

Gateway是什么?(SpringCloudAlibaba组件)

1、网关介绍 **网关(Gateway)又称网间连接器、协议转换器。网关在传输层上以实现网络互连&#xff0c;是最复杂的网络互连设备&#xff0c;仅用于两个高层协议不同的网络互连。**网关的结构也和路由器类似&#xff0c;不同的是互连层。网关既可以用于广域网互连&#xff0c;也可…

IP证书申请

目录 申请IP证书的基本条件&#xff1a; 申请和使用公网IP证书的过程&#xff1a; 为什么需要申请IP地址证书&#xff1f; 申请IP证书&#xff1a; IP证书又称公网IP地址证书&#xff0c;是一种特殊的SSL/TLS证书&#xff0c;其作用原理和普通的域名证书很像&#xff0c;域…

使用 Cloudflare 和全栈框架实现快速开发

去年 Cloudflare 发布了一系列新功能&#xff0c;使在 Cloudflare 上部署 Web 应用程序变得更加容易&#xff0c;我们看到 Astro、Next.js、Nuxt、Qwik、Remix、SolidStart、SvelteKit 和其他托管 Web 应用程序的大幅增长。 近日 Cloudflare 对这些 Web 框架的集成模块进行了重…

思诺流体邀您探索科技前沿2024年第13届生物发酵展

参展企业介绍 保定思诺流体科技有限公司是一家集研发、生产、销售于一体的高新技术企业。从事蠕动泵、蠕动泵软管、蠕动泵OEM产品、蠕动泵灌装系统等的研发、生产与销售。产品在科研实验室、化工、印刷、环保、水处理等领域得到了广泛应用。 “思诺”取自“Signal”的英…

Linux学习记录20——文件的隐藏权限

一.学习的内容 Linux系统中的文件除了具备一般权限和特殊权限之外&#xff0c;还有一种隐藏权限&#xff0c;即被隐藏起来的权限&#xff0c;默认情况下不能直接被用户发觉。既然叫隐藏权限&#xff0c;那么使用常规的ls命令肯定不能看到它的真面目。隐藏权限的专用设置命令是 …

认识JAVA语言(一)扩充

Java语言的程序控制结构 (2.5) 在Java语言中&#xff0c;程序的流程控制对于代码执行的逻辑有着至关重要的作用。通过条件控制和循环控制&#xff0c;程序可以做出决策、重复执行任务&#xff0c;并在合适的时间退出。本章将详细介绍这些结构&#xff0c;并通过代码示例和表格来…

D1084是一款具有5A输出能力、低压差为1.5V的三端稳压器。采用TO-220、TO-263和TO-252封装形式

1、 概述&#xff1a; D1084是一款具有5A输出能力、低压差为1.5V的三端稳压器。输出电压可通过电位器调节或1.5V, 1.8V, 3.3V三个固定电压版。内含电流限制和热保护功能&#xff0c;防止任何过载时产生过高的结温。D1084系列电路有标准TO-220、TO-263和TO-252封装形式。 2、 典…

短剧APP开发:探索剧情新领域,畅享精彩短剧时光

随着移动互联网的快速发展&#xff0c;短剧作为一种新兴的内容形式&#xff0c;以其短小精悍、情节紧凑的特点&#xff0c;逐渐受到广大用户的喜爱。为了满足用户对短剧内容的日益增长需求&#xff0c;我们决定开发一款全新的短剧APP&#xff0c;为用户带来前所未有的观剧体验。…

鼠标灵敏度怎么调,鼠标灵敏度怎么调最稳

鼠标和键盘是操作计算机过程中使用最频繁的设备之一,用电脑的时,我敢说你一定离不开鼠标。有些用户发现鼠标不太好用,尤其是在游戏时,总觉得鼠标移动太慢了。另外,如果你感觉鼠标按键失灵、鼠标单击变双击以及反应迟钝等等,出现这样的问题,应该是鼠标灵敏度没有调整好。…

先锋阀门带您领略2024第13届生物发酵装备展

参展企业介绍 温州先锋阀门有限公司坐落于【中国阀门城】---温州市龙湾&#xff0c;是一家集研发、设计、制造、销售和服务为一体的科技创新型企业。拥有10多项国家专利&#xff0c;三个产品荣获中国通用机械工业协会颁发的(中国国际阀门博览会)银奖称号&#xff0c;部分产品还…

干货 | 探索CUTTag:从样本到文库,实验步步为营!

CUT&Tag&#xff08;Cleavage Under Targets and Tagmentation&#xff09;是一种新型DNA-蛋白互作研究技术&#xff0c;主要用于研究转录因子或组蛋白修饰在全基因组上的结合或分布位点。相比于传统的ChIP-seq技术&#xff0c;CUT&Tag反应在细胞内进行&#xff0c;创新…

win10鼠标无限转圈圈是什么原因,win10系统鼠标无限转圈圈

win10鼠标无限转圈圈是什么原因?一般后台有程序在运行,鼠标出现圆圈转动则代表正在加载中,等待一会就好了。若如果转了好久的圈圈,程序没有响应,点击桌面也没有反应,则尝试打开任务管理器,将未响应或异常的程序强制结束掉。其实,出现这种情况,有可能是win10系统中的一…

HarmonyOS4.0 ArkUI常用组件

一、Image 语法&#xff1a; Image(src:string|PixelMap|Resource)使用方式&#xff1a; string格式&#xff1a;用来加载网络图片&#xff0c;需要在module.json5中申请网络访问权限&#xff1a;ohos.permission.INTERNET Image("http://xxx.png")PixelMap格式&am…