vue视频、图片自动轮播并伴随进度条

news2025/1/10 1:35:48

在这里插入图片描述

废话不多说直接上代

多余没用的部分自己看着删除

<template>
  <div class="showImg">
    <el-carousel ref="carousel" trigger="hover" :autoplay="false" class="dimControl" :height="`${(currenInnerWith*0.375) > 3840 ? 1440 : currenInnerWith*0.375}px`"
                 @change="carouselChange" :interval="5000" arrow="never" style="cursor: pointer;">
      <el-carousel-item v-for="(item,index) in imgArr" :key="item.id">

        <!-- @timeupdate="commonVideoUpdata(index,'video')" -->
        <template v-if="item.banner_type==2 && isIndex==index">
          <video
            :ref="'videoRef'+index"
            @click="gotoBanner(item)"
            class="box-bg video-bg"
            :class="'videoRef'+index"
            :id="'videoRef'+index"
            :muted="true"
            autoplay="autoplay"
            @mouseover="changeInterval(true)"
            @mouseleave="changeInterval(false)"
            :poster="item.video_cover_url"
            :src="item.video_url"/>
          <span v-if="isAudioBox" class="audio-box" @click="handleAudio(index,9)">
            <i v-if="!isIcon" class="iconfont audio-icon" @click.stop="handleAudio(index,true)">&#xe6de;</i>
            <i v-if="isIcon" class="iconfont audio-icon" @click.stop="handleAudio(index,false)">&#xe6db;</i>
          </span>


        </template>

        <div
          v-else
          @click="gotoBanner(item)"
          class="box-bg"
          @mouseover="changeInterval(true)"
          @mouseleave="changeInterval(false)"
          :style="`background-image:url(${item.url});height:${(currenInnerWith*0.375) > 3840?1440:currenInnerWith*0.375}px`"
          alt="#"
          :src="item.url"
        />
      </el-carousel-item>
    </el-carousel>
    <div class="category-list">
    </div>
  </div>
</template>

<script>
import axiosSrr from "@/plugins/ssr-axios";


export default {
  props: {
    datas: {
      type: Object
    },
    isSwiperTool: {
      type: Boolean,
      default: true
    }
  },

  async fetch(){
      return axiosSrr.post("/banner/OWI_GetBanner", {
        banner_code: "home_banner"
      }).then((res) => {
        let retData = [];
        res.data.data.entities.forEach((item, i) => {
          let arr = {};
          arr.url = item.image_url;
          arr.id = i;
          arr.display_order = Number(item.display_order);
          arr.redirect_url = item.redirect_url;

          arr.banner_type = item.banner_type;
          arr.image_url2 = item.image_url2;
          arr.image_url3 = item.image_url3;
          arr.video_cover_url = item.video_cover_url;
          arr.video_url = item.video_url;
          retData.push(arr);
        });

        this.imgArr = retData;
        this.banner_duration = res.data.data.banner_duration



      });
  },

  data() {
    return {
      currentIndex: 0, //当前所在图片下标
      timer: null, //定时轮询
      imgArr: [],
      carouselData: {
        pic: {
          // master: require("@/assets/img/bitmap.png"),
          master: [
            require("@/assets/banner-bg/banner1_4k.png"),
            require("@/assets/banner-bg/banner1_4k.png"),
            require("@/assets/banner-bg/banner1_4k.png")
          ],

          gifs: require("@/assets/img/dynamic_graph.png")
        }
      },

     
      screenWidth: 1440,
      industryData: [], //banner 下行业分类信息
      notice: '',
      currentTimeProgress: 0,
      isIndex: 0,
      intervalId: null,
      timeInterval: null,
      banner_duration: 5,
      isAudio: false,
      isIcon: false,
      isAudioBox: false,
      isCount: 0,
      currenInnerWith:1920,
      loopTimer:false,

    };
  },

 
  methods: {
    openTip() {
    },
    async getNotice() {
      let dataRet = await this.$axios.post("common_api/OWI_GetAnnouncementList")
      this.notice = dataRet.data.msg_list
    },
    /**
     * 屏幕尺寸判断
     */
    screenChange(e) {
      if(!process.browser){
        return
      }
      let width = document.body.clientWidth;
      // let width = 3840;

      let p = "";
      // p=width < 2048?e[0]:(2048 <= width && width < 3840?e[1]:e[2])
      if (width < 2048) {
        p = e[0];
      } else if (2048 <= width && width < 3840) {
        p = e[1];
      } else {
        p = e[2];
      }
      return p;
    },
    //开启定时器
    startIntervals() {
      // 事件里定时器应该先清除在设置,防止多次点击直接生成多个定时器
      clearInterval(this.timer);
      this.timer = setInterval(() => {
        this.currentIndex++;
        if (this.currentIndex > this.imgArr.length - 1) {
          this.currentIndex = 0;
        }
      }, 5000);
    },
    // 点击左右箭头
    clickIcon(val) {
      if (val === "down") {
        this.currentIndex++;
        if (this.currentIndex === this.imgArr.length) {
          this.currentIndex = 0;
        }
      } else {
        /* 第一种写法
					this.currentIndex--;
					if(this.currentIndex < 0){
						this.currentIndex = this.imgArr.length-1;
					} */
        // 第二种写法
        if (this.currentIndex === 0) {
          this.currentIndex = this.imgArr.length;
        }
        this.currentIndex--;
      }
    },
    // 点击控制圆点
    changeImg(index) {
      this.currentIndex = index;
    },
    /**
     * 鼠标移入事件
     */
    enter(e, id) {
      this.currentIndex = id;
    },
    //鼠标移入移出控制
    changeInterval(val) {
      if (val) {
        clearInterval(this.timer);

      } else {
        // this.startInterval();
      }
    },
    gotoBanner(val) {
      if (val.redirect_url) {
        window.open(val.redirect_url);
      }
    },
    getIndustryImg(val) {
      switch (val) {
        case "直播":
          return require("@/assets/img/cover_trade_ZhiBo.png");
          break;
        case "数字营销":
          return require("@/assets/img/cover_trade_ShuZiYingXiao.png");
          break;
        case "数据新闻":
          return require("@/assets/img/cover_trade_ShuJuXinWen.png");
          break;
        case "短视频":
          return require("@/assets/img/cover_trade_DuanShiPin.png");
          break;
        case "数字创意":
          return require("@/assets/img/cover_trade_ShuZiChuangYi@2x.png");
          break;
        case "数字文物":
          return require("@/assets/img/cover_trade_ShuZiWenWu@2x.png");
          break;
        case "桥梁模型":
          return require("@/assets/img/cover_trade_bridge@2x.png");
          break;
        case "数字信息":
          return require("@/assets/img/cover_trade_ShuZiXinXi.png");
          break;
      }
    },
    // 获取行业应用
    async getIndustryApplication() {
      let res = await this.$axios.post("/banner/OWI_GetBanner", {
        banner_code: "home_industry_application"
      });
      let arr=[]
      let arrSort=res.data.entities?.sort((a, b) => {
          return a.display_order - b.display_order;
        })
      arrSort?.map(item=>{
        arr.push({
          url: item.redirect_url,
          bg: item.image_url
        })
      })
      if (process.browser) {
        this.$nextTick(() => {
          this.industryData = arr
        })
      }
    },
    async getindustryData() {
      let res = await this.$axios.post("/api_source/OWI_TreeCategoryV2", {
        category_type: 10,
        current_category_show_id: "",
        only_show_categories: true
      });
      this.industryData = [];
      let industryIndex = 0;

      let mapData = new Map();


      res.data.entities.forEach(item => {

        let industryitem = item.self;
        industryitem.bg = this.getIndustryImg(industryitem.name);
        industryitem.url = `/web_site_front/resources/resources_model_new1?parentVal=行业应用&ClassName=${industryitem.name}&showId=${industryitem.show_id}`;
        industryitem.title = industryitem.name;
        mapData.set(industryitem.title, industryitem)
        //this.industryData.push(industryitem);
        //industryIndex++;
      });
      

      let freeObj = {
        name: '限时免费',
        url: 'https://www.cgpool.com/web_site_front/resourcesArea/resources_zone_info?id=300',
        bg: require('@/assets/img/cover_trade_Xianshi@2x.png')
      }

      mapData.set(freeObj.name, freeObj)

      let bridge = {
        name: '桥梁模型',
        url: 'https://www.cgpool.com/web_site_front/resourcesArea/resources_zone_info?id=290',
        bg: require('@/assets/img/cover_trade_bridge@2x.png')
      }

      mapData.set(bridge.name, bridge)

      let digiDecoration = {
        name: '数字家装',
        url: 'https://www.cgpool.com/web_site_front/resourcesArea/resources_zone_info?id=301',
        bg: require('@/assets/img/cover_trade_jiazhuang@2x.png')
      }

      mapData.set(digiDecoration.name, digiDecoration)


      let intelligentManufacture = {
        name: '智能制造',
        url: 'https://www.cgpool.com/web_site_front/resourcesArea/resources_zone_info?id=209',
        bg: require('@/assets/img/cover_trade_zhizao@2x.png')
      }

      mapData.set(intelligentManufacture.name, intelligentManufacture)


      let BAndB = {
        name: '民宿模型',
        url: 'https://www.cgpool.com/web_site_front/resourcesArea/resources_zone_info?id=292',
        bg: require('@/assets/img/cover_trade_minsu@2x.png')
      }

      mapData.set(BAndB.name, BAndB)

      // 2024 0408 需求更改
      // 1 限时免费 2 数字创意  3 数字家装 4 智能制造  5 桥梁模型 6 短视频
      let tmpArray = [];
      let Index1 = mapData.get("限时免费")
      tmpArray.push(Index1)
      let Index2 = mapData.get("数字创意")
      tmpArray.push(Index2)
      let Index3 = mapData.get("数字家装")
      tmpArray.push(Index3)
      let Index4 = mapData.get("智能制造")
      tmpArray.push(Index4)
      let Index5 = mapData.get("桥梁模型")
      tmpArray.push(Index5)
      let Index6 = mapData.get("民宿模型")
      tmpArray.push(Index6)
      // this.industryData = tmpArray

      // this.industryData.splice(1,1)
      // this.industryData.splice(2,0,sliceArr[0])

      /**
       *
       */
    },
    async getBanner() {
      let res = await this.$axios.post("/banner/OWI_GetBanner", {
        banner_code: "home_banner"
      });
      this.banner_duration = res.data.banner_duration;
      this.imgArr=[]
      res.data.entities.forEach((item, i) => {
        let arr = {};
        arr.url = item.image_url;
        arr.id = i;
        arr.display_order = Number(item.display_order);
        arr.redirect_url = item.redirect_url;

        arr.banner_type = item.banner_type;
        arr.image_url2 = item.image_url2;
        arr.image_url3 = item.image_url3;
        arr.video_cover_url = item.video_cover_url;
        arr.video_url = item.video_url;
        this.imgArr.push(arr);
      });
      if (this.imgArr.length > 0) {
        this.createElChange()
        this.carouselChange(0)
      }

    },
    // 公共video获取时间
    commonVideoUpdata(id, type) {
      const self = this
      if(!process.browser){
        return
      }
      let videoEl = document.getElementsByClassName('videoRef' + id)


      videoEl[0]?.addEventListener("timeupdate", function () {
        let el = document.querySelector(".new-indicator")
        if (el) {
          let currTime = this.currentTime //当前时间
          let duration = this.duration //总时间
          let pre = currTime / duration
          self.setStyleHandel(pre * 40)
          if (this.currentTime == this.duration) {
            self.handelNext()
            return
          }
        }
      })

    },
    handleToggleImg() {
      const self = this
      let time = self.banner_duration * 1000
      let times = self.banner_duration * 1000 + 300
      clearInterval(self.intervalId);
      if(!process.browser){
        return
      }
      let el = document.querySelector(".new-indicator")
      if (el) {
        let count = 0; // 计数器
        // let intervalId; // 用于保存 setInterval 返回的 ID
        function executeTask() {
          // 执行任务的逻辑,这里假设是打印当前计数
          count++; // 增加计数
          self.setStyleHandel((40 / (time / 100)) * count)
          if (count === time / 100) {
            // 达到执行次数上限,停止定时器
            clearInterval(self.intervalId);
          }
        }

        // 每200毫秒执行一次 executeTask 函数
        self.intervalId = setInterval(executeTask, 100);
        // 5秒后停止定时器
        clearInterval(self.timeInterval);
        self.timeInterval = setInterval(() => {
          clearInterval(self.intervalId);
          clearInterval(self.timeInterval);
          self.handelNext()
        }, times);
      }
    },

    setStyleHandel(count) {
      if(!process.browser){
        return
      }
      let el = document.querySelector(".new-indicator")
      el.style.opacity = 1
      el.style = "background: #fff"
      el.style.width = `${count >= 6 ? count : 6}px`
    },
    carouselChange(e) {
      if (process.browser) {
        this.isIndex = e
        this.isAudioBox = true
        this.isAudio = false
        this.isIcon = false
        this.isCount = 0
        clearInterval(this.intervalId);
        clearInterval(this.timeInterval);
        if (process.browser) {
          this.$nextTick(() => {

            this.handleSetLeft()

            let el = document.querySelectorAll(".new-indicator")
            el?.forEach(function (indicator) {
              indicator.style = "width:6px"
              indicator.style = "opacity:0"
              indicator.style = "background: rgba(255, 255, 255, 0.45)"
            });
            this.imgArr?.map((item, i) => {
              let videoObj = this.$refs['videoRef' + i]

              if (Object(videoObj).length > 0) {
                videoObj[0].currentTime = 0
                setTimeout(() => {
                  videoObj[0].play()
                }, 500);


                // let playTimer=setTimeout(() => {
                //   // videoObj[0].muted=false
                //   videoObj[0].play()
                // },500);
                // clearTimeout(playTimer);
              }

            })
            this.createElChange()
            if (Object(this.imgArr).length > 0) {
              el.forEach(item => {
                item.style = `width:${0}%`
              })
            }
            if (this.imgArr[e].banner_type == 1) {
              this.handleToggleImg()
            } else {
              this.commonVideoUpdata(e, 'video')
            }
          })
        }
      }
    },
    handleAudio(id, Boolean) {
      const self = this
      self.isCount++
      // 获取 video 元素
      const myVideo = self.$refs['videoRef' + id];
      // 切换静音状态
      self.isAudio = !self.isAudio;
      // 更新视频静音状态
      myVideo[0].muted = self.isAudio;
      self.isIcon = !self.isAudio
      // 如果是第一次点击,并且视频正在播放,触发播放
      if (!self.isAudio && !myVideo[0].paused) {
        myVideo[0].play();
      }

      if (self.isCount == 1) {
        this.handleAudio(id, Boolean)
      }
    },

    handelNext() {
      if (process.server){
        return
      }
      this.isAudioBox = false;
      if (this.imgArr?.length == 1 && this.imgArr[this.isIndex]?.banner_type == 2) {
        this.isCount++;
        this.isIcon = true
        this.isAudioBox = true;
        // 获取 video 元素
        const myVideo = this.$refs["videoRef" + this.isIndex];
        myVideo?.forEach((item, i) => {
          item.muted = true
        })
      }
      this.$refs.carousel?.next();
      if (this.imgArr.length == 1) {
        this.carouselChange(0);
      }
    },
    createElChange() {
      if (process.browser) {
        this.$nextTick(() => {
          let indicators = document.querySelectorAll(".new-indicator")
          // 删除这些元素
          indicators.forEach(function (indicator) {
            indicator.parentNode.removeChild(indicator);
          });
          const indicatorElement = this.$refs.carousel.$el.querySelector('.el-carousel__indicator.is-active');
          const newElement = document.createElement('span');
          newElement.textContent = '';
          newElement.className = 'new-indicator';
          newElement.style.width = `6px`;
          newElement.style.opacity = `0`;
          indicatorElement?.appendChild(newElement);
        })
      }
    },
    handleSetLeft() {
      if (process.browser) {
        this.$nextTick(() => {
          let element = document.querySelector(".showImg .el-carousel__indicators")
          let audio = document.querySelector(".showImg .audio-box")
          let leftDistance = element.getBoundingClientRect().left;
          // 输出距离
          if (audio) {
            audio.style = `left:${leftDistance + window.pageXOffset + element.clientWidth + 12}px`
          }
        })
      }


    },
    gotoIndustryInfo(val) {
      window.open(val.url);
    }
  },
  //进入页面后启动定时轮询
  mounted() {
    // this.getindustryData();
    this.getIndustryApplication();
    this.getBanner();
    this.startIntervals();
    this.startIntervals();
    this.getNotice();
    const self = this
    window.addEventListener("resize", function () {
      self.handleSetLeft()

      if (!self.loopTimer) { // 使用节流机制,降低函数被触发的频率
        self.loopTimer = true;
        setTimeout(function () {
          window.screenWidth = window.innerWidth;
          self.loopTimer = false;
          self.$nextTick(() => {
            if(window.screenWidth>3840){
              self.currenInnerWith = 3840

            }else{
              self.currenInnerWith = window.screenWidth;

            }
          })

        }, 100)
      }
    });
    if(window.innerWidth>3840){
      this.currenInnerWith = 3840
    }else{
      this.currenInnerWith = window.innerWidth;
    }
  },
  destroyed() {
    // 组件销毁后解绑事件
    window.onresize = null;
  },
};
</script>

<style lang="scss" scoped>
$desktop2: "only screen and (max-width: 1295px)";
$desktop: "only screen and (min-width: 1296px)";
$desktop1500: "only screen and (min-width: 1500px)";
$desktop1501: "only screen and (min-width: 1501px) and (max-width: 1799px)";
$desktop1800: "only screen and (min-width: 1800px)";
$desktop_3840: "only screen and (min-width: 3840px)";
$desktop_4000: "only screen and (min-width: 4000px)";
.fontText {
  @media #{$desktop} {
    margin: 0 72px;
  }
  @media #{$desktop1500} {
    margin: 0 56px;
  }
  @media #{$desktop1501} {
    margin: 0 72px;
  }
  @media #{$desktop1800} {
    margin: 0 72px;
  }
  @media #{$desktop2} {
    margin: 0 72px;
  }
  @media #{$desktop_3840} {
    margin: 0px auto;
  }
  @media #{$desktop_4000} {
    margin: 0px auto;
  }
  margin: 0px;
}

* {
  padding: 0;
  margin: 0;
}

/* 清除li前面的圆点 */
li {
  list-style-type: none;
}

.showImg {
  position: relative;
  width: 100%;
  // height: 587px;
  background: #fafafa;

  .box-category {
    // position: absolute;
    // top: calc(100% - 48px);
    // right: calc((100% - 1440px) / 2 - -220px);
    transform: translateY(-50%);
    width: 64px;
    height: 30px;
    border-radius: 15px;
    background-color: rgba(25, 27, 41, 0.45);
    line-height: 30px;
    text-align: center;
    font-size: 25px;
    cursor: pointer;
    color: rgba(255, 255, 255, 0.45);
    margin-right: 8px;
    margin-top: 14px;

    i {
      font-weight: bold;
    }
  }

  .box-bg {
    // height: 585px;
    width: 100%;
    height: 100%;
    max-width: 3840px;
    max-height: 1440px;
    background-repeat: no-repeat;
    margin: 0 auto;

    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;

    .img-box {
      width: 365px;
      position: absolute;
      left: calc((100% - 1440px) - -15px);
      z-index: 2;

      img {
        max-width: 100%;
        margin-top: 290px;
      }
    }
  }

  .video-bg {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .audio-box {
    border-radius: 50%;
    background-color: #00000073;
    height: 40px;
    width: 40px;
    position: absolute;
    bottom: 26px;
    text-align: center;
    line-height: 40px;

    &:hover {
      background-color: rgba(255, 255, 255, 0.25);
    }

    .audio-icon {
      cursor: pointer;
      color: #fff;
    }
  }

}

/* 轮播图片 */
.showImg img {
  width: 100%;
  height: 100%;
}

/* 箭头图标 */
.iconDiv {
  display: inline-block;
}

.iconDiv:hover {
  color: #fff;
}

/* 控制圆点 */
.banner-box {
  position: absolute;
  right: calc((100% - 1440px) / 2 - -70px);
  top: calc(100% - 63px);
  display: flex;
}

.banner-circle {
  height: 20px;

  background-color: rgba(25, 27, 41, 0.45);
  border-radius: 15px;
  line-height: 30px;
  height: 30px;
}

.banner-circle ul {
  margin: 0 20px;
  height: 100%;
  display: flex;
}

.banner-circle ul li {
  display: inline-block;
  width: 14px;
  height: 14px;
  margin: 0 5px;
  border-radius: 7px;
  background-color: rgba(255, 255, 255, 0.3);
  cursor: pointer;
  align-self: center;
}

.active {
  background-color: #ffffff !important;
  width: 30px !important;
  border-radius: 7px !important;
}

@keyframes hoverLi {
  0% {
    width: 14px;
  }
  25% {
    width: 20px;
  }
  50% {
    width: 24px;
  }
  75% {
    width: 28px;
  }
  100% {
    width: 30px;
  }
}

.active:hover {
  animation-name: hoverLi;
  animation-duration: 3s;
}

.category-list {
  margin: 0 auto;
  align-self: center;
}

::v-deep .el-carousel {
  width: 100vw;
}

::v-deep .el-carousel__item {
  width: 100%;
}

::v-deep .el-carousel__indicators {
  height: 40px;
  padding: 0 28px;
  background: rgba(0, 0, 0, 0.45);
  border-radius: 20px;
  bottom: 26px;
  // left: 75%;

  .el-carousel__indicator {
    line-height: 40px;
    height: 40px;
    margin-top: 0px;
  }

  .el-carousel__indicator--horizontal {
    padding: 12px 0;
    margin: 0 4px;
  }

  .is-active {
    max-width: 40px;
    position: relative;

    .new-indicator {
      width: 6px;
      height: 8px;
      position: absolute;
      top: 15px;
      border-radius: 6px;
      transition: width .3s;
    }

    .el-carousel__button {
      width: 40px;
      height: 8px;
      border-radius: 6px;
      background: rgba(255, 255, 255, 0.45);

    }
  }

  .el-carousel__button {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.45);
    margin-top: 3px;
  }
}

.category-list {
  .fontText {
    display: flex;
    justify-content: space-between;
    // margin:0 72px;
    margin-top: 40px;
    min-width: 1296px;
    max-width: 3678px;
    font-family: Alibaba-PuHuiTi-B;

    .hangyeImgSty {
      width: 40px;
      height: 40px;
      position: relative;
      top: 8px;
      margin-right: 10px;
    }

    .Notice {
      width: 426px;
      height: 56px;
      background: url("@/assets/img/NoticeBg.png") no-repeat;
      background-size: 100% 100%;
      display: flex;
      cursor: pointer;
      //  align-items: center;
      .NoticeIcon {
        width: 24px;
        height: 24px;
        margin: 16px 12px 16px 24px;

      }

      span {
        line-height: 52px;
        height: 56px;
      }
    }
  }

}

</style>

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

JavaScript:移除元素

这是原题&#xff1a;给你一个数组 nums 和一个值 val&#xff0c;你需要 原地 移除所有数值等于 val 的元素。元素的顺序可能发生改变。然后返回 nums 中与 val 不同的元素的数量。 假设 nums 中不等于 val 的元素数量为 k&#xff0c;要通过此题&#xff0c;您需要执行以下操…

sourcrinlight 4.0 的使用技巧:如何在文件名后省略路径名

如图&#xff1a; 如果路径名很长&#xff0c;将显示不了几个文件名的&#xff0c;会造成一些不便。如何隐藏文件的路径名呢&#xff1f; 选中或取消这个按钮&#xff1a; 就可以了。要想再查看文件路径&#xff0c;鼠标放上去&#xff0c;就会显示了&#xff1a; 谢谢

数据融合工具(11)悬挂点自动检测和修复

一、需求背景 GIS数据通常需要满足拓扑规则&#xff0c;即点、线和面之间的拓扑关系应该正确。 悬挂点是指在地图数据中孤立存在的点&#xff0c;它们不与任何线或面的节点相连接。悬挂点通常是数据中的异常情况&#xff0c;可能是由于数字化或数据编辑错误而导致的。 下图以橙…

【关闭个人数据跨境传输】

现象 &#xff1a;WIN10更新补丁重启就有了这&#xff1b; 解决办法&#xff1a; 第一步&#xff1a;按shiftF10 第二步&#xff1a;按winR 第三步&#xff1a;输入taskmgr&#xff0c;回车 第四步&#xff1a;结束Microsoft账户进程&#xff0c;就可以进入桌面&#xff1…

Android中OkHttp3中超时时间概述

目录 前言connectTimeoutreadTimeoutwriteTimeoutcallTimeoutpingInterval拓展 前言 可以看到&#xff0c;使用还是很简单的。主要相关的有这五个参数&#xff0c;其中我们常用到是就是connectTimeout、readTimeout和writeTimeout。 再看上图&#xff0c;可以看到默认下connec…

matlab小白入门的基本使用

一.基本运算 加&#xff1a;a55 减&#xff1a;a5-2 立方&#xff1a;a2^3 乘&#xff1a;a2*3 ans默认变量名&#xff0c;应答最近依次操作运算结果eps浮点数的相对误差i,j虚数单位&#xff0c;定义-1inf代表无穷大NaN代表不定值&#xff08;不是数字&#xff09;pi圆周率…

【内网安全】横向移动-Wmi-Smb-CME密码喷射

目录 环境介绍域信息收集-横向移动前置判断是不是在域内获取域控主机的内网ip端口扫描内网获取主机密码 域横向移动-WMI-自带&命令&套件&插件1.wmic系统自带&#xff1a;(单执行&#xff1a;即无回显) 2.cscript系统自带&#xff1a;(交互式) 3.wmiexec-impacket&a…

[RuoYi-Vue] - 6. 若依二次开发

文章目录 &#x1f333;1. 模块定制(修改包名)1.1 若依框架修改器1.2 使用示例 &#x1f33f;2. 新建业务模块2.1 新建子模块2.2 版本锁定2.3 添加模块依赖 &#x1f33e;3. 菜品管理开发3.1 准备SQL并导入数据库3.2 配置代码生成信息3.3 下载代码并导入项目 &#x1f343;4. 通…

【Linux】深入了解`rm`命令:删除文件与目录的终极指南

文章目录 一、rm命令概述二、rm命令的基本用法三、rm命令的常用选项1. -i&#xff1a;交互式删除2. -f&#xff1a;强制删除3. -r或-R&#xff1a;递归删除目录4. -v&#xff1a;详细模式 四、rm命令的高级用法1. 结合其他命令使用2. 删除空目录 五、rm命令的注意事项 在Linux操…

Neither the JAVA_HOME nor the JRE_HOME environment variable is defined问题解决

一、系统环境变量中添加tomcatjdk的环境变量声明 1、右击此电脑->属性->高级系统设置 可复制粘贴下面的变量名 CATALINA_HOME 点击path->编辑->新建 可将下面值粘入 %CATALINA_HOME%\bin 2、配置jdk的系统变量 系统变量->新建->如图 可将下面变量名粘入 J…

【java】力扣 H指数

文章目录 题目链接题目描述思路代码 题目链接 274.H指数 题目描述 思路 设置n为citations的长度&#xff0c;也就是发表论文的篇数&#xff0c;h肯定是不能超过n的&#xff0c;所以当有引用次数大于n时&#xff0c;我们要看成n&#xff0c; 要创建一个数组arr&#xff0c;来…

牛客 7.13 月赛(留 C逆元 Ddp)

B-最少剩几个&#xff1f;_牛客小白月赛98 (nowcoder.com) 思路 奇数偶数 奇数&#xff1b;奇数*偶数 奇数 所以在既有奇数又有偶数时&#xff0c;两者结合可以同时删除 先分别统计奇数&#xff0c;偶数个数 若偶个数大于奇个数&#xff0c;答案是偶个数-奇个数 若奇个数…

揭秘失眠的幕后黑手:你为何辗转难眠?

揭秘失眠的幕后黑手&#xff1a;你为何辗转难眠&#xff1f; 在这个快节奏的时代&#xff0c;失眠已经成为许多人的“隐形杀手”。你是否也曾在夜深人静时&#xff0c;躺在床上辗转反侧&#xff0c;望着天花板发呆&#xff0c;数着绵羊也无法入睡&#xff1f;今天&#xff0c;…

【CSS in Depth 2 精译_018】3.1.2 逻辑属性 + 3.1.3 用好逻辑属性的简写形式

当前内容所在位置&#xff08;可进入专栏查看其他译好的章节内容&#xff09; 第一章 层叠、优先级与继承&#xff08;已完结&#xff09; 1.1 层叠1.2 继承1.3 特殊值1.4 简写属性1.5 CSS 渐进式增强技术1.6 本章小结 第二章 相对单位&#xff08;已完结&#xff09; 2.1 相对…

在 Windows 上运行 Linux:WSL2 完整指南(二)

系列文章目录 在 Windows 上运行 Linux&#xff1a;WSL2 完整指南&#xff08;一&#xff09;&#x1f6aa; 在 Windows 上运行 Linux&#xff1a;WSL2 完整指南&#xff08;二&#xff09;&#x1f6aa; 文章目录 系列文章目录前言四、常见问题及解决方法问题二&#xff1a;0…

本地部署,edge-tts文本转语音解决方案

目录 什么是 edge-tts&#xff1f; 主要特点 应用场景 优势 开始使用 edge-tts 命令行安装 edge-tts 库&#xff1a; docker安装 未来展望 总结 https://github.com/rany2/edge-ttshttps://github.com/rany2/edge-tts 随着科技的进步&#xff0c;文本转语音&#xff…

PyCharm查看文件或代码变更记录

背景&#xff1a; Mac笔记本上有一个截图的定时任务在运行&#xff0c;本地Python使用的是PyCharm IDE&#xff0c;负责的同事休假&#xff0c;然后定时任务运行的结果不符合预期&#xff0c;一下子不知道问题出现在哪里。 定位思路&#xff1a; 1、先确认网络、账号等基本的…

Flutter动画详解第二篇之显式动画(Explicit Animations)

目录 前言 一、定义 1.AnimationController 1.常用属性 1. value 2. status 3. duration 2.常用方法 1.forward 2.reverse 3.repeat 4.stop 5. reset 6. animateTo(double target, {Duration? duration, Curve curve Curves.linear}) 7.animateBack(double ta…

android R ext4 image打包脚本介绍

一、Android R打包指令使用介绍 &#xff08;1&#xff09;mkuserimg_mke2fs #./mkuserimg_mke2fs --help usage: mkuserimg_mke2fs [-h] [--android_sparse] [--journal_size JOURNAL_SIZE][--timestamp TIMESTAMP] [--fs_config FS_CONFIG][--product_out PRODUCT_OUT][--b…

Nginx、LNMP万字详解

目录 Nginx 特点 Nginx安装 添加Nginx服务 Nginx配置文件 全局配置 HTTP配置 状态统计页面 Nginx访问控制 授权用户 授权IP 虚拟主机 基于域名 测试 基于IP 测试 基于端口 测试 LNAMP 解析方式 LNMP转发php-fpm解析 Nginx代理LAMP解析 LNMP部署示例 实…