【vue+echarts】绘制中国地图,3D地图,省、市、县三级下钻以及回钻,南海诸岛小窗化显示,点位飞线图,点位名称弹窗轮播展示,及一些常见问题

news2025/1/14 4:17:10

在这里插入图片描述
先看效果展示图
在这里插入图片描述

目录

      • 准备工作
      • 一, 绘制3D地图
        • 1,调用官网地址接口获取
        • 2,去官网下载中国地图的json数据到本地,本地引入
      • 二, 南海诸岛小窗化显示
        • 1, 手动过滤掉,只保留小窗化的南海诸岛
        • 2, 代码层面过滤掉,只保留小窗化的南海诸岛
      • 三, 省、市、县三级地图下钻及回钻
        • 1, 下钻
        • 2, 回钻
      • 四, 添加点位飞线图
      • 五, 点位弹窗轮播展示
      • 常见问题
        • 1, 南海诸岛小窗不显示或者小窗和大图同时显示
        • 2, 鼠标移入地图不显示弹窗,移入点位上显示弹窗

每部分的源码在文章最后的链接中

准备工作

不知道或者不熟悉的可以去官网看看: 点击前往Echarts官网
各个省、市、县的地图json下载,点击前往
插件下载

npm i echarts --save  // 我的版本 ^5.2.0

一, 绘制3D地图

这种3D效果其实多层map对象集合组成的,通常在option里面的geo中
html

  <div class="about">
    <div id="myMap"></div>
  </div>

option配置项

option里面的控制3D效果的主要是这个geo模块,里面5个对象表示5层地图,层数越多,就越立体,一般三五层就差不多了,每个都偏移了一点点,从而形成的3D立体效果

      optionMap: {
 		....
         geo: [
          {
            map: 'china',
            aspectScale: 1,
            zoom: 0.9,
            layoutCenter: ['50%', '50%'],
            layoutSize: '100%',
            show: true,
            roam: false,
            label: {
              show: false, // 各个省市县的名字
              color: '#fff',
            },
            itemStyle: {
              // 每块的样式
              areaColor: {
                type: 'linear',
                x: 1200,
                y: 0,
                x2: 0,
                y2: 0,
                colorStops: [
                  {
                    offset: 0,
                    color: 'rgba(3,27,78,0.75)',
                  },
                  {
                    offset: 1,
                    color: 'rgba(58,149,253,0.75)',
                  },
                ],
                global: true, // 缺省为 false
              },
              borderColor: '#c0f3fb',
              borderWidth: 0.8,
            },
            emphasis: {
              itemStyle: {
                show: false,
                color: '#fff',
                areaColor: 'rgba(0,254,233,0.6)',
              },
              label: {
                show: true,
                color: '#fff',
              },
            },
          },
          // 重影
          {
            type: 'map',
            map: 'china',
            zlevel: -1,
            aspectScale: 1,
            zoom: 0.9,
            layoutCenter: ['50%', '51%'],
            layoutSize: '100%',
            roam: false,
            silent: true,
            itemStyle: {
              borderWidth: 1,
              borderColor: 'rgba(58,149,253,0.8)',
              shadowColor: 'rgba(172, 122, 255,0.5)',
              shadowOffsetY: 5,
              shadowBlur: 15,
              areaColor: 'rgba(5,21,35,0.1)',
            },
          },
          {
            type: 'map',
            map: 'china',
            zlevel: -2,
            aspectScale: 1,
            zoom: 0.9,
            layoutCenter: ['50%', '52%'],
            layoutSize: '100%',
            roam: false,
            silent: true,
            itemStyle: {
              borderWidth: 1,
              borderColor: 'rgba(58,149,253,0.6)',
              shadowColor: 'rgba(65, 214, 255,0.6)',
              shadowOffsetY: 5,
              shadowBlur: 15,
              areaColor: 'rgba(5,21,35,0.1)',
            },
          },
          {
            type: 'map',
            map: 'china',
            zlevel: -3,
            aspectScale: 1,
            zoom: 0.9,
            layoutCenter: ['50%', '53%'],
            layoutSize: '100%',
            roam: false,
            silent: true,
            itemStyle: {
              borderWidth: 1,
              borderColor: 'rgba(58,149,253,0.4)',
              shadowColor: 'rgba(29, 111, 165,1)',
              shadowOffsetY: 15,
              shadowBlur: 10,
              areaColor: 'rgba(5,21,35,0.1)',
            },
          },
          {
            type: 'map',
            map: 'china',
            zlevel: -4,
            aspectScale: 1,
            zoom: 0.9,
            layoutCenter: ['50%', '54%'],
            layoutSize: '100%',
            roam: false,
            silent: true,
            itemStyle: {
              borderWidth: 5,
              borderColor: 'rgba(5,9,57,0.8)',
              shadowColor: 'rgba(29, 111, 165,0.8)',
              shadowOffsetY: 15,
              shadowBlur: 10,
              areaColor: 'rgba(5,21,35,0.1)',
            },
          },
        ],
        ....
      },
      publicUrl: 'https://geo.datav.aliyun.com/areas_v3/bound/',

js
两种绘制方法

1,调用官网地址接口获取
import axios from 'axios'
let myChartMap = null
methods:{
    // 初始化
    async initChart() {
    //获取中国地图的json数据,直接拿过来用
      let chinaGeoJson = await this.getGeoJson('100000_full.json')
      this.initEcharts(chinaGeoJson.data, 'china')
    },
    //echarts绘图
    initEcharts(geoJson, name) {
    // 注册3D地图
      this.$echarts.registerMap(name, geoJson)
      myChartMap.setOption(this.optionMap)
    },
    //获取地图json数据
    async getGeoJson(jsonName) {
      return await axios.get(this.publicUrl + jsonName)
    },
},
mounted() {
myChartMap = this.$echarts.init(document.getElementById('myMap'))
this.initChart()
}
2,去官网下载中国地图的json数据到本地,本地引入

本地引入的比较简洁点,但是在地图下面模块就不好用了,总不可能把全国的省市县地图json全下载下来吧,当然也可以,这样项目体积就比较大了

methods:{
    initEcharts() {
      this.$echarts.registerMap('china', require('../util/china.json'))
      myChartMap.setOption(this.optionMap)
    },
},
mounted() {
myChartMap = this.$echarts.init(document.getElementById('myMap'))
this.initEcharts()
}

看看效果图
在这里插入图片描述
哎,这里出现了一个问题,南海诸岛和南海诸岛小窗化一起出来了,以下有两个解决方法

二, 南海诸岛小窗化显示

1, 手动过滤掉,只保留小窗化的南海诸岛

手动删除海南省其余json,只保留海南省的. 和剔除海南省边界json
本地china.json
在这里插入图片描述
全局搜JD,删除properties对象就可以了.
在这里插入图片描述
手动将上面两块代码删除就可以小窗化显示了.

2, 代码层面过滤掉,只保留小窗化的南海诸岛

相同的部分就不再展示了
formatJson这个方法做的就是剔除海南省其余json,只保留海南省的. 和剔除海南省边界json

methods:{
    // 南沙诸岛以缩略图展示
    async formatJson(chinaGeoJson) {
      chinaGeoJson.features.forEach((v) => {
        if (v.properties && v.properties.name == '海南省') {
          v.geometry.coordinates = v.geometry.coordinates.slice(0, 1)
        }
      })
      // 过滤掉海南诸岛边界线
      chinaGeoJson.features = chinaGeoJson.features.filter((item) => item.properties.adcode !== '100000_JD')
      return chinaGeoJson
    },
     // 初始化
    async initChart() {
      let chinaGeoJson = await this.getGeoJson('100000_full.json')
      // this.initEcharts(chinaGeoJson.dat, 'china')
      // 过滤掉海南省其他部分的json之后的中国地图json
      let formatChinaGeoJson = await this.formatJson(chinaGeoJson.data)
      this.initEcharts(formatChinaGeoJson, 'china')
    },
    ...
}

过滤后,就能正常显示了,请看下图
在这里插入图片描述

三, 省、市、县三级地图下钻及回钻

原理: 通过点击事件点击的省份,获取该省的行政区划编码—>以这个编码作为参数去调接口获取该省的地图json—>重新渲染到页面上—>递归操作

1, 下钻
  publicUrl: 'https://geo.datav.aliyun.com/areas_v3/bound/', // 地图json接口地址
  level: 0, // 当前层级
  historyData: [], // 缓存上一级的信息
  adName: '中国', // json对应的中文name
  alladcode: '', // 中文名对应的行政区划编码
.....
  methods:{
  ......
  	    // 初始化
    async initChart() {
      // 获取地图name对应的adcode行政区划编码
      let geoJson = await this.getGeoJson('all.json')
      this.alladcode = geoJson.data
      // 获取中国地图json,南海诸岛小窗化
      let chinaGeoJson = await this.getGeoJson('100000_full.json')
      let formatChinaGeoJson = await this.formatJson(chinaGeoJson.data)
      this.initEcharts(formatChinaGeoJson, 'china')
    },
        // 格式图表,数据处理
    formatChart(geoJson, name) {
    // 页面上回钻按钮的name
      this.adName = name == 'china' ? '中国' : name
      // 注册3D地图
      this.$echarts.registerMap(name, geoJson)
      // 下钻的时候地图大小设置,不设置会有部分地图超出屏幕
      this.optionMap.geo.forEach((v) => {
        v.map = name
        v.layoutSize = name == 'china' ? '180%' : '100%'
      })
      myChartMap.clear()
      myChartMap.setOption(this.optionMap)
    },
      //echarts绘图
    initEcharts(geoJson, name) {
      this.formatChart(geoJson, name)
      // 存储当前下钻的层级和地图json信息
      this.level++
      this.historyData.push({ geoJson, name })
      // 点击事件
      myChartMap.off('click')
      myChartMap.on('click', (params) => {
      	// 获取中文名对应的行政区划编码,调接口用的
        let clickRegionCode = this.alladcode.filter((areaJson) => areaJson.name === params.name)[0].adcode
        // 没有区县的地级市,东莞,中山,儋州,三沙,嘉峪关, 这5个市比较特殊,没有下一级区县,在获取地图json官网接口可以看出来,中国,省,市,这三级的地图json的接口是 '行政区划+_full.json'的,而最后一级区县的地图json接口是 '行政区划+.json'.由于这5个地级市没有区县,所以他们就是最后一级,所以他们接口参数格式是'行政区划+.json'
        let adcodeArr = ['460400', '460300', '441900', '442000', '620200']
        let regJson = `${clickRegionCode}_full.json`
        // 区县或者没有区县的地级市,行政区划最后两位不是00的就是最后一级,adcodeArr除外
        if (clickRegionCode.toString().slice(-2) != '00' || adcodeArr.includes(clickRegionCode.toString())) {
          regJson = `${clickRegionCode}.json`
        }
        // 调接口
        this.getGeoJson(regJson)
          .then((regionGeoJson) => {
          	// 递归
            this.initEcharts(regionGeoJson.data, params.name)
          })
          .catch((err) => {
          	// 异常处理
            this.level = 0
            this.historyData = []
            this.initEcharts(require('@/util/china.json'), 'china')
          })
      })
    },
    //获取地图json数据
    async getGeoJson(jsonName) {
      return await axios.get(this.publicUrl + jsonName)
    },
2, 回钻

上面下钻不是缓存了当前层的json信息吗,直接拿过来用就好了,接口都不用调.
回钻可以通过按钮点击进行回钻,也可以监听鼠标右键进行回钻,我这边就用按钮了,简单点

    <el-button type="primary" size="mini" title="点击返回上一级" class="btn" @click="upside">{{ adName }}</el-button>
...
	methods:{
		 // 返回上一级
	    upside() {
	      // 如果是最顶层就返回,没得回钻了
	      if (this.historyData.length <= 1) return
	      // 回钻一层,level减减, historyData移出一层
	      this.level--
	      this.historyData.pop()
	      let upData = this.historyData[this.level - 1]
	      this.formatChart(upData.geoJson, upData.name)
	    },
	}

看看效果在这里插入图片描述

四, 添加点位飞线图

每一条飞线都是由一组起始点的经纬度组成的,起点就是点位的经纬度,终点就是自定义的一组点位,可以项目所在地的经纬度.

项目里面就调接口获取点位就可以了,这里就用假数据展示了,只要数据格式一样就行

    // 点位数据
    this.resData = [
      {
        name: '广州市',
        value: [113.2644, 23.1291],
      },
      {
        name: '成都市',
        value: [104.0657, 30.6598],
      },
      {
        name: '苏州市',
        value: [120.6195, 31.2995],
      },
      {
        name: '北京市',
        value: [116.404, 39.9042],
      },
      {
        name: '连云港市',
        value: [119.1676, 34.5934],
      },
      {
        name: '南京市',
        value: [118.7674, 32.0415],
      },
      {
        name: '杭州市',
        value: [120.1535, 30.2874],
      },
      {
        name: '乌鲁木齐市',
        value: [87.6168, 43.7928],
      },
      {
        name: '拉萨市',
        value: [91.11, 29.97],
      },
      {
        name: '西安市',
        value: [108.953, 34.2779],
      },
      {
        name: '南宁市',
        value: [108.32006, 22.82402],
      },
    ]
    ...
...
import { isPointInMultiPolygon } from '@/util/echartTool.js' // 这个是判断点位是否属于当前区域,地图下钻的时候,过滤掉不属于该区域的点位

	    series: [
          {
            type: 'lines', // 飞线图
            zlevel: 2,
            effect: {
              show: true,
              period: 3, //箭头指向速度,值越小速度越快
              trailLength: 0.03, //特效尾迹长度[0,1]值越大,尾迹越长重
              symbol: 'arrow', //箭头图标
              symbolSize: 6, //图标大小
            },
            lineStyle: {
              color: '#EE5652',
              width: 1, //尾迹线条宽度
              opacity: 1, //尾迹线条透明度
              curveness: 0.3, //尾迹线条曲直度
            },
            data: [],
            symbol: ['none', 'circle'], //飞线起点终点点位样式
            symbolSize: 10, // 飞线起点终点点位大小
          },
          {
            type: 'effectScatter',
            zlevel: 3,
            coordinateSystem: 'geo',
            emphasis: {
              label: {
                show: true,
                position: 'top',
                color: '#fff',
                formatter: '{b|{b}}',
              },
            },
            data: [],
            symbol: 'circle',
            symbolSize: [20, 10],
            itemStyle: {
              color: 'orange',
              shadowBlur: 10,
              shadowColor: 'orange',
            },
            effectType: 'ripple',
            showEffectOn: 'render', //emphasis移入显示动画,render一开始显示动画
            rippleEffect: {
              scale: 5,
              brushType: 'stroke',
            },
          },
        ],
        ..... //无关的代码就不展示了,上面都有
          // 初始化
    async initChart() {
      // 获取地图name对应的adcode行政区划编码
      let geoJson = await this.getGeoJson('all.json')
      this.alladcode = geoJson.data
      let chinaGeoJson = await this.getGeoJson('100000_full.json')
      let formatChinaGeoJson = await this.formatJson(chinaGeoJson.data)
      // 鼠标移入点位的弹窗
      let rich = {
        b: {
          color: '#fff',
          backgroundColor: {
            image: require('../../public/home/point.png'),
          },
          padding: [20, 30],
          fontSize: 14,
          align: 'center',
        },
      }
      this.optionMap.series[1].emphasis.label.rich = rich // 控制鼠标移入点位弹窗显示点位信息
      this.initEcharts(formatChinaGeoJson, 'china')
    },
    // 格式化点位飞线数据
    filterLines(currentData) {
      let dataLines = []
      let center = [120.537612, 31.276282] // 飞线图终点的地位经纬度
      currentData.forEach((v) => {
        let lonLat = [v.value[0], v.value[1]]
        dataLines.push({
          coords: [lonLat, center], // 高版本的飞线数据组
        })
        // 这个是低版本的
        // dataLines.push([
        //   {
        //     coord: lonLat, // 起始点
        //     value: 0,
        //   },
        //   {
        //     coord: center, // 中心点
        //   },
        // ])
      })
      return dataLines
    },

    // 格式图表
    formatChart(geoJson, name) {
      // 过滤出当前地图的点位,过滤掉不属于改地图区域的点位
      let currentData = this.resData.filter((v) => {
        return isPointInMultiPolygon([v.value[0], v.value[1]], geoJson.features)
      })
      this.adName = name == 'china' ? '中国' : name
      this.$echarts.registerMap(name, geoJson)
      this.optionMap.geo.forEach((v) => {
        v.map = name
        v.layoutSize = name == 'china' ? '180%' : '100%'
      })
      this.optionMap.series[0].data = this.filterLines(currentData)
      this.optionMap.series[1].data = currentData
      myChartMap.clear()
      myChartMap.setOption(this.optionMap)
    },
  .....

echartTool.js 射线法判断点位是否属于某个区域内

// 判断当前经纬度是否在规定区域内
export function isPointInMultiPolygon(point, multiPolygons) {
  for (let polygon of multiPolygons) {
    let coordinates = polygon.geometry.coordinates
    if (isPointInAnyPolygon(point, coordinates)) {
      return true
    }
  }
  return false
}
export function isPointInAnyPolygon(point, polygons) {
  for (let polygon of polygons) {
    if (isPointInPolygon(point, polygon[0])) {
      return true
    }
  }
  return false
}
export function isPointInPolygon(point, polygon) {
  // 射线法判断点是否在多边形内部
  let x = point[0],
    y = point[1]
  let inside = false
  for (let i = 0, j = polygon.length - 1; i < polygon.length; j = i++) {
    let xi = polygon[i][0],
      yi = polygon[i][1]
    let xj = polygon[j][0],
      yj = polygon[j][1]
    let intersect = yi > y !== yj > y && x < ((xj - xi) * (y - yi)) / (yj - yi) + xi
    if (intersect) {
      inside = !inside
    }
  }
  return inside
}

看看效果
在这里插入图片描述

五, 点位弹窗轮播展示

定时器循环展示点位信息,当前点位高亮且显示弹窗,其余不显示.

....
      series: [
          {
            type: 'effectScatter',
            zlevel: 3,
            coordinateSystem: 'geo',
            emphasis: {
              label: {
                show: true,
                position: 'top',
                color: '#fff',
                formatter: '{b|{b}}',
              },
            },
            label: {
              show: false,
              position: 'top',
              color: '#fff',
            },
            data: [],
            symbol: 'circle',
            symbolSize: [20, 10],
            itemStyle: {
              color: 'orange',
              shadowBlur: 10,
              shadowColor: 'orange',
            },
            effectType: 'ripple',
            showEffectOn: 'render', //emphasis移入显示动画,render一开始显示动画
            rippleEffect: {
              scale: 5,
              brushType: 'stroke',
            },
          },
        ],
        ...
            // 初始化
    async initChart() {
....
      // 鼠标移入点位的弹窗
      let rich = {
        b: {
          color: '#fff',
          backgroundColor: {
            image: require('../../public/home/point.png'),
          },
          padding: [20, 30],
          fontSize: 14,
          align: 'center',
        },
      }
      this.optionMap.series[0].emphasis.label.rich = rich
      this.optionMap.series[0].label.rich = rich
      this.initEcharts(formatChinaGeoJson, 'china')
    },
        // 点位颜色高亮
    highLightPoint(currentData, index) {
      currentData.forEach((v, key) => {
        let flag = key == index ? 'aqua' : 'orange'
        v.itemStyle = {
          color: flag,
          shadowColor: flag,
        }
      })
      this.optionMap.series[0].label.formatter = (e) => {
        return e.name === currentData[index].name ? `{b|${e.name}}` : ''
      }
    },
        // 格式图表
    formatChart(geoJson, name) {
      // 过滤出当前地图的点位
      let currentData = this.resData.filter((v) => {
        return isPointInMultiPolygon([v.value[0], v.value[1]], geoJson.features)
      })
      this.adName = name == 'china' ? '中国' : name
      this.$echarts.registerMap(name, geoJson)
      this.optionMap.geo.forEach((v) => {
        v.map = name
        v.layoutSize = name == 'china' ? '180%' : '100%'
      })
      this.optionMap.series[0].data = currentData
      // 点位颜色高亮,初始进入第一个高亮
      this.highLightPoint(currentData, 0)
      this.optionMap.series[0].label.show = true
      myChartMap.clear()
      myChartMap.setOption(this.optionMap)
      if (charTimer) {
        clearInterval(charTimer)
        charTimer = null
      }
      // 点位大于2个才循环轮播
      if (currentData.length > 1) {
        let i = 0
        charTimer = setInterval(() => {
          i++
          if (i >= currentData.length) i = 0
          this.highLightPoint(currentData, i)
          myChartMap.setOption(this.optionMap)
        }, 1000 * 3)
      }
    },
    ....

看效果
在这里插入图片描述

常见问题

1, 南海诸岛小窗不显示或者小窗和大图同时显示

小窗不显示大概率是注册3D地图的时候用的中文名.

 this.$echarts.registerMap(name, geoJson)
 绘制全国地图的时候这个name必须是china,写中国的话很可能导致南海诸岛不显示.

小窗和大图同时显示
就下图这种情况,南沙诸岛重复显示,上面第二大点已经给出解决方法了
在这里插入图片描述

2, 鼠标移入地图不显示弹窗,移入点位上显示弹窗

把全局的toolip关掉

....
option:{
    tooltip: {
     	show: false,
     },
     series:[
		...
		    {
			...
			// 控制鼠标移入高亮,改变位置,就类似于弹窗了
            emphasis: {
              label: {
                show: true,
                position: 'top',
                color: '#fff',
                formatter: '{b|{b}}', // 自定义样式
              },
            },
            // 默认的弹窗样式
            label:{
            }
   ....
          },
	 ]
}

所有示例代码已上传,点击前往下载

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

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

相关文章

深度学习 --- stanford cs231学习笔记(一)

stanford cs231学习笔记(一) 1&#xff0c;先是讲到了机器学习中的kNN算法&#xff0c;然后因为kNN分类器的一些弊端&#xff0c;引入了线性分类器。 kNN算法的三大弊端&#xff1a; (1)&#xff0c;计算量大&#xff0c;当特征比较多时表示性差 (2)&#xff0c;训练时耗时少…

C++初阶之模板初阶

一、泛型编程 如何实现一个通用的交换函数呢&#xff1f; void Swap(int& left, int& right) {int temp left;left right;right temp; } void Swap(double& left, double& right) {double temp left;left right;right temp; } void Swap(char& left,…

sql编写规范(word原件)

编写本文档的目的是保证在开发过程中产出高效、格式统一、易阅读、易维护的SQL代码。 1 编写目的 2 SQL书写规范 3 SQL编写原则 软件全套资料获取进主页或者本文末个人名片直接获取。

[Java、Android面试]_22_APP启动流程(中频问答)

欢迎查看合集&#xff1a; Java、Android面试高频系列文章合集 本人今年参加了很多面试&#xff0c;也有幸拿到了一些大厂的offer&#xff0c;整理了众多面试资料&#xff0c;后续还会分享众多面试资料。 整理成了面试系列&#xff0c;由于时间有限&#xff0c;每天整理一点&am…

偏微分方程算法之混合边界条件下的差分法

目录 一、研究目标 二、理论推导 三、算例实现 四、结论 一、研究目标 我们在前几节中介绍了Poisson方程的边值问题&#xff0c;接下来对椭圆型偏微分方程的混合边值问题进行探讨&#xff0c;研究对象为&#xff1a; 其中&#xff0c;为矩形区域&#xff0c;为上的连续函数…

毕业设计参考-PyQt5-YOLOv8-鱼头鱼尾鱼长测量程序,OpenCV、Modbus通信、YOLO目标检测综合应用

“PyQt5-YOLOv8-鱼头鱼尾鱼长测量程序”是一个特定的软件程序&#xff0c;用于通过图像处理和目标检测技术来测量鱼类的长度。 视频效果&#xff1a; 【毕业设计】基于yolo算法与传统机器视觉的鱼头鱼尾识别_哔哩哔哩_bilibili 这个程序结合了多种技术&#xff1a; 1. OpenCV…

【数据结构(邓俊辉)学习笔记】列表03——有序列表

文章目录 0. 概述1. 唯一化2. 查找2.1 实现2.2 顺序查找2.3 复杂度 0. 概述 介绍下有序列表。 若列表中所有节点的逻辑次序与其大小次序完全一致&#xff0c;则称作有序列表&#xff08;sorted list&#xff09;。为保证节点之间可以定义次序&#xff0c;依然假定元素类型T直接…

【一刷《剑指Offer》】面试题 12:打印 1 到最大的 n 位数

力扣对应题目链接&#xff1a;LCR 135. 报数 - 力扣&#xff08;LeetCode&#xff09; 牛客对应题目链接&#xff1a;打印从1到最大的n位数_牛客题霸_牛客网 (nowcoder.com) 一、《剑指Offer》内容 二、分析题目 1、暴力解法 2、用字符串模拟数字加法 首先要考虑当 n 很大时&…

Pandas层级索引

文章目录 第1关&#xff1a;多级索引的取值与切片第2关&#xff1a;多级索引的数据转换与累计方法 第1关&#xff1a;多级索引的取值与切片 编程要求 本关的编程任务是补全右侧上部代码编辑区内的相应代码&#xff0c;要求实现如下功能&#xff1a; 使用MultiIndex创建如下Da…

Vue3+.NET6前后端分离式管理后台实战(十七)

1&#xff0c;Vue3.NET6前后端分离式管理后台实战(十七)已经在微信公众号更新&#xff0c;有兴趣的扫码关注一起交流学习。

ShardingSphere 5.x 系列【30】影子库

有道无术,术尚可求,有术无道,止于术。 本系列Spring Boot 版本 3.1.0 本系列ShardingSphere 版本 5.4.0 源码地址:https://gitee.com/pearl-organization/study-sharding-sphere-demo 文章目录 1. 影子库与全链路压测2. 核心概念3. 使用限制4. 执行原理4.1 DML 语句4.2 D…

Vue前端环境准备

vue-cli Vue-cli是Vue官方提供的脚手架&#xff0c;用于快速生成一个Vue项目模板 提供功能&#xff1a; 统一的目录结构 本地调试 热部署 单元测试 集成打包上线 依赖环境&#xff1a;NodeJs 安装NodeJs与Vue-Cli 1、安装nodejs&#xff08;已经安装就不用了&#xff09; node-…

指挥中心操作台的选择至关重要

在指挥中心的环境中&#xff0c;操作台是核心设备&#xff0c;它承载着信息收集、处理、分发的重要任务。其选择应考虑到多方面的因素&#xff0c;包括外观、材质、稳定性、操作便利性以及技术支持等。嘉德立在这里给大家详细的总结一下选择指挥中心操作台的要点。 首先&#x…

docker挂载数据卷-以nginx为例

目录 一、什么是数据卷 二、数据卷的作用 三、如何挂载数据卷 1、创建nginx容器挂载数据卷 2、查看数据卷 3、查看数据卷详情 4、尝试在宿主机修改数据卷 5、查看容器内对应的数据卷目录 6、 访问nginx查看效果 ​​​​​​​一、什么是数据卷 挂载数据卷本质上就是实…

Ansible之性能调优

有很多人说Ansible的执行效率比SaltStack差&#xff0c;确实&#xff0c;默认使用的SSH方式通信&#xff0c;效率远低于SaltStack的zeromq消息队列。但是我们可以优化Ansible的执行速度&#xff0c;可以做到并不比SaltStack差。 1. 开启SSH长连接 在OpenSSH 5.6版本后&#xf…

【Proteus】LED呼吸灯 直流电机调速

1.LED呼吸灯 #include <REGX51.H> sbit LEDP2^0; void delay(unsigned int t) {while(t--); } void main() {unsigned char time,i;while(1){for(time0;time<100;time){for(i0;i<20;i){LED0;delay(time);LED1;delay(100-time);}}for(time100;time>0;time--){fo…

【软件测试理论002】认识软件缺陷、缺陷生命周期、缺陷分类

目录 1 认识软件缺陷 1.1 什么是软件缺陷 1.2 缺陷存在哪些方面 1.3 软件缺陷示例 1.4 软件缺陷的表现形式 1.5 软件缺陷产生的原因 1.6 软件缺陷的根源 1.7 软件缺陷修复的费用 2 软件缺陷的信息分类 2.1 软件缺陷的生命周期 2.2 软件缺陷的信息 2.3 软件缺陷分类…

论文| What makes visual place recognition easy or hard?

论文| What makes visual place recognition easy or hard?

【C语言】简单有趣的扫雷游戏

**©作者:末央&#xff06; ©系列:C语言初阶(适合小白入门) ©说明:以凡人之笔墨&#xff0c;书写未来之大梦 目录 一、分析游戏规则二、分文件三、菜单实现四、游戏内容核心实现1.初始化棋盘2.打印棋盘3.布置雷4.排查雷5.game()函数实现调用 五、全部源码 一、分…

【JAVA项目】基于ssm的协同过滤算法的【图书推荐系统】

技术简介&#xff1a;采用B/S架构、ssm 框架、Java技术、MySQL等技术实现。 系统简介&#xff1a;系统权限按管理员和用户这两类涉及用户划分。&#xff08;1&#xff09;管理员功能需求 管理员登陆后&#xff0c;主要包括首页、个人中心、用户管理、书籍管理、书籍分类管理、热…