echarts属性之dataZoom

news2025/1/6 5:08:28

dataZoom-slider

滑动条型数据区域缩放组件(dataZoomInside)

滑动条型数据区域缩放组件提供了数据缩略图显示,缩放,刷选,拖拽,点击快速定位等数据筛选的功能。下图显示了该组件可交互部分

所有属性

dataZoom-slider. type = 'slider'

string

dataZoom-slider. id

string

组件 ID。默认不指定。指定则可用于在 option 或者 API 中引用组件。

dataZoom-slider. show = true 试一试

boolean

是否显示 组件。如果设置为 false,不会显示,但是数据过滤的功能还存在。

dataZoom-slider. backgroundColor = 'rgba(47,69,84,0)' 试一试

Color

组件的背景颜色。

 dataZoom-slider. dataBackground

Object

数据阴影的样式。

  dataZoom-slider.dataBackground. lineStyle

Object

阴影的线条样式

所有属性

{ color , width , type , dashOffset , cap , join , miterLimit , shadowBlur , shadowColor , shadowOffsetX , shadowOffsetY , opacity }

  dataZoom-slider.dataBackground. areaStyle

Object

阴影的填充样式

所有属性

{ color , shadowBlur , shadowColor , shadowOffsetX , shadowOffsetY , opacity }

 dataZoom-slider. selectedDataBackground

Object

从 v5.0.0 开始支持

选中部分数据阴影的样式。

  dataZoom-slider.selectedDataBackground. lineStyle

Object

选中部分阴影的线条样式

所有属性

{ color , width , type , dashOffset , cap , join , miterLimit , shadowBlur , shadowColor , shadowOffsetX , shadowOffsetY , opacity }

  dataZoom-slider.selectedDataBackground. areaStyle

Object

选中部分阴影的填充样式

所有属性

{ color , shadowBlur , shadowColor , shadowOffsetX , shadowOffsetY , opacity }

dataZoom-slider. fillerColor = 'rgba(167,183,204,0.4)' 试一试

Color

选中范围的填充颜色。

dataZoom-slider. borderColor = '#d2dbee' 试一试

Color

边框颜色。

dataZoom-slider. borderRadius = 3 试一试

numberArray

圆角半径,单位px,支持传入数组分别指定 4 个圆角半径。 如:

borderRadius: 5, // 统一设置四个角的圆角大小
borderRadius: [5, 5, 0, 0] //(顺时针左上,右上,右下,左下)
dataZoom-slider. handleIcon 试一试

string

两侧缩放手柄的 icon 形状,支持路径字符串,默认为:

'M-9.35,34.56V42m0-40V9.5m-2,0h4a2,2,0,0,1,2,2v21a2,2,0,0,1-2,2h-4a2,2,0,0,1-2-2v-21A2,2,0,0,1-11.35,9.5Z'

可以通过 'image://url' 设置为图片,其中 URL 为图片的链接,或者 dataURI

URL 为图片链接例如:

'image://http://example.website/a/b.png'

URL 为 dataURI 例如:

'image://'

可以通过 'path://' 将图标设置为任意的矢量路径。这种方式相比于使用图片的方式,不用担心因为缩放而产生锯齿或模糊,而且可以设置为任意颜色。路径图形会自适应调整为合适的大小。路径的格式参见 SVG PathData。可以从 Adobe Illustrator 等工具编辑导出。

例如:

'path://M30.9,53.2C16.8,53.2,5.3,41.7,5.3,27.6S16.8,2,30.9,2C45,2,56.4,13.5,56.4,27.6S45,53.2,30.9,53.2z M30.9,3.5C17.6,3.5,6.8,14.4,6.8,27.6c0,13.3,10.8,24.1,24.101,24.1C44.2,51.7,55,40.9,55,27.6C54.9,14.4,44.1,3.5,30.9,3.5z M36.9,35.8c0,0.601-0.4,1-0.9,1h-1.3c-0.5,0-0.9-0.399-0.9-1V19.5c0-0.6,0.4-1,0.9-1H36c0.5,0,0.9,0.4,0.9,1V35.8z M27.8,35.8 c0,0.601-0.4,1-0.9,1h-1.3c-0.5,0-0.9-0.399-0.9-1V19.5c0-0.6,0.4-1,0.9-1H27c0.5,0,0.9,0.4,0.9,1L27.8,35.8L27.8,35.8z'
dataZoom-slider. handleSize = '100%' 试一试

numberstring

控制手柄的尺寸,可以是像素大小,也可以是相对于 dataZoom 组件宽度的百分比,默认跟 dataZoom 宽度相同。

 dataZoom-slider. handleStyle

Object

两侧缩放手柄的样式配置。

 dataZoom-slider.handleStyle. color = #fff 试一试

Color

图形的颜色。

支持使用rgb(255,255,255)rgba(255,255,255,1)#fff等方式设置为纯色,也支持设置为渐变色和纹理填充,具体见option.color

 dataZoom-slider.handleStyle. borderColor = #ACB8D1 试一试

Color

图形的描边颜色。支持的颜色格式同 color,不支持回调函数。

 dataZoom-slider.handleStyle. borderWidth 试一试

number

描边线宽。为 0 时无描边。

 dataZoom-slider.handleStyle. borderType = 'solid' 试一试

stringnumberArray

描边类型。

可选:

  • 'solid'
  • 'dashed'
  • 'dotted'

自 v5.0.0 开始,也可以是 number 或者 number 数组,用以指定线条的 dash array,配合 borderDashOffset 可实现更灵活的虚线效果。

例如:

{

borderType: [5, 10],

borderDashOffset: 5
}
 dataZoom-slider.handleStyle. borderDashOffset 试一试

number

从 v5.0.0 开始支持

用于设置虚线的偏移量,可搭配 borderType 指定 dash array 实现灵活的虚线效果。

更多详情可以参考 MDN lineDashOffset。

 dataZoom-slider.handleStyle. borderCap = 'butt' 试一试

string

从 v5.0.0 开始支持

用于指定线段末端的绘制方式,可以是:

  • 'butt': 线段末端以方形结束。
  • 'round': 线段末端以圆形结束。
  • 'square': 线段末端以方形结束,但是增加了一个宽度和线段相同,高度是线段厚度一半的矩形区域。

默认值为 'butt'。 更多详情可以参考 MDN lineCap。

 dataZoom-slider.handleStyle. borderJoin = 'bevel' 试一试

string

从 v5.0.0 开始支持

用于设置2个长度不为0的相连部分(线段,圆弧,曲线)如何连接在一起的属性(长度为0的变形部分,其指定的末端和控制点在同一位置,会被忽略)。

可以是:

  • 'bevel': 在相连部分的末端填充一个额外的以三角形为底的区域, 每个部分都有各自独立的矩形拐角。
  • 'round': 通过填充一个额外的,圆心在相连部分末端的扇形,绘制拐角的形状。 圆角的半径是线段的宽度。
  • 'miter': 通过延伸相连部分的外边缘,使其相交于一点,形成一个额外的菱形区域。这个设置可以通过 borderMiterLimit 属性看到效果。

默认值为 'bevel'。 更多详情可以参考 MDN lineJoin。

 dataZoom-slider.handleStyle. borderMiterLimit = 10 试一试

number

从 v5.0.0 开始支持

用于设置斜接面限制比例。只有当 borderJoin 为 miter 时, borderMiterLimit 才有效。

默认值为 10。负数、0Infinity 和 NaN 均会被忽略。

更多详情可以参考 MDN miterLimit。

 dataZoom-slider.handleStyle. shadowBlur 试一试

number

图形阴影的模糊大小。该属性配合 shadowColor,shadowOffsetXshadowOffsetY 一起设置图形的阴影效果。

示例:

{
    shadowColor: 'rgba(0, 0, 0, 0.5)',
    shadowBlur: 10
}
 dataZoom-slider.handleStyle. shadowColor 试一试

Color

阴影颜色。支持的格式同color

 dataZoom-slider.handleStyle. shadowOffsetX 试一试

number

阴影水平方向上的偏移距离。

 dataZoom-slider.handleStyle. shadowOffsetY 试一试

number

阴影垂直方向上的偏移距离。

 dataZoom-slider.handleStyle. opacity = 1 试一试

number

图形透明度。支持从 0 到 1 的数字,为 0 时不绘制该图形。

dataZoom-slider. moveHandleIcon 试一试

string

从 v5.0.0 开始支持

移动手柄中间的 icon,支持路径字符串,默认为:

'M-320.9-50L-320.9-50c18.1,0,27.1,9,27.1,27.1V85.7c0,18.1-9,27.1-27.1,27.1l0,0c-18.1,0-27.1-9-27.1-27.1V-22.9C-348-41-339-50-320.9-50z M-212.3-50L-212.3-50c18.1,0,27.1,9,27.1,27.1V85.7c0,18.1-9,27.1-27.1,27.1l0,0c-18.1,0-27.1-9-27.1-27.1V-22.9C-239.4-41-230.4-50-212.3-50z M-103.7-50L-103.7-50c18.1,0,27.1,9,27.1,27.1V85.7c0,18.1-9,27.1-27.1,27.1l0,0c-18.1,0-27.1-9-27.1-27.1V-22.9C-130.9-41-121.8-50-103.7-50z'

可以通过 'image://url' 设置为图片,其中 URL 为图片的链接,或者 dataURI

URL 为图片链接例如:

'image://http://example.website/a/b.png'

URL 为 dataURI 例如:

'image://'

可以通过 'path://' 将图标设置为任意的矢量路径。这种方式相比于使用图片的方式,不用担心因为缩放而产生锯齿或模糊,而且可以设置为任意颜色。路径图形会自适应调整为合适的大小。路径的格式参见 SVG PathData。可以从 Adobe Illustrator 等工具编辑导出。

例如:

'path://M30.9,53.2C16.8,53.2,5.3,41.7,5.3,27.6S16.8,2,30.9,2C45,2,56.4,13.5,56.4,27.6S45,53.2,30.9,53.2z M30.9,3.5C17.6,3.5,6.8,14.4,6.8,27.6c0,13.3,10.8,24.1,24.101,24.1C44.2,51.7,55,40.9,55,27.6C54.9,14.4,44.1,3.5,30.9,3.5z M36.9,35.8c0,0.601-0.4,1-0.9,1h-1.3c-0.5,0-0.9-0.399-0.9-1V19.5c0-0.6,0.4-1,0.9-1H36c0.5,0,0.9,0.4,0.9,1V35.8z M27.8,35.8 c0,0.601-0.4,1-0.9,1h-1.3c-0.5,0-0.9-0.399-0.9-1V19.5c0-0.6,0.4-1,0.9-1H27c0.5,0,0.9,0.4,0.9,1L27.8,35.8L27.8,35.8z'
dataZoom-slider. moveHandleSize = 7 试一试

number

从 v5.0.0 开始支持

移动手柄的尺寸高度。

 dataZoom-slider. moveHandleStyle

Object

从 v5.0.0 开始支持

移动手柄的样式配置。

 dataZoom-slider.moveHandleStyle. color = #D2DBEE 试一试

Color

图形的颜色。

支持使用rgb(255,255,255)rgba(255,255,255,1)#fff等方式设置为纯色,也支持设置为渐变色和纹理填充,具体见option.color

 dataZoom-slider.moveHandleStyle. borderColor = '#000' 试一试

Color

图形的描边颜色。支持的颜色格式同 color,不支持回调函数。

 dataZoom-slider.moveHandleStyle. borderWidth 试一试

number

描边线宽。为 0 时无描边。

 dataZoom-slider.moveHandleStyle. borderType = 'solid' 试一试

stringnumberArray

描边类型。

可选:

  • 'solid'
  • 'dashed'
  • 'dotted'

自 v5.0.0 开始,也可以是 number 或者 number 数组,用以指定线条的 dash array,配合 borderDashOffset 可实现更灵活的虚线效果。

例如:

{

borderType: [5, 10],

borderDashOffset: 5
}
 dataZoom-slider.moveHandleStyle. borderDashOffset 试一试

number

从 v5.0.0 开始支持

用于设置虚线的偏移量,可搭配 borderType 指定 dash array 实现灵活的虚线效果。

更多详情可以参考 MDN lineDashOffset。

 dataZoom-slider.moveHandleStyle. borderCap = 'butt' 试一试

string

从 v5.0.0 开始支持

用于指定线段末端的绘制方式,可以是:

  • 'butt': 线段末端以方形结束。
  • 'round': 线段末端以圆形结束。
  • 'square': 线段末端以方形结束,但是增加了一个宽度和线段相同,高度是线段厚度一半的矩形区域。

默认值为 'butt'。 更多详情可以参考 MDN lineCap。

 dataZoom-slider.moveHandleStyle. borderJoin = 'bevel' 试一试

string

从 v5.0.0 开始支持

用于设置2个长度不为0的相连部分(线段,圆弧,曲线)如何连接在一起的属性(长度为0的变形部分,其指定的末端和控制点在同一位置,会被忽略)。

可以是:

  • 'bevel': 在相连部分的末端填充一个额外的以三角形为底的区域, 每个部分都有各自独立的矩形拐角。
  • 'round': 通过填充一个额外的,圆心在相连部分末端的扇形,绘制拐角的形状。 圆角的半径是线段的宽度。
  • 'miter': 通过延伸相连部分的外边缘,使其相交于一点,形成一个额外的菱形区域。这个设置可以通过 borderMiterLimit 属性看到效果。

默认值为 'bevel'。 更多详情可以参考 MDN lineJoin。

 dataZoom-slider.moveHandleStyle. borderMiterLimit = 10 试一试

number

从 v5.0.0 开始支持

用于设置斜接面限制比例。只有当 borderJoin 为 miter 时, borderMiterLimit 才有效。

默认值为 10。负数、0Infinity 和 NaN 均会被忽略。

更多详情可以参考 MDN miterLimit。

 dataZoom-slider.moveHandleStyle. shadowBlur 试一试

number

图形阴影的模糊大小。该属性配合 shadowColor,shadowOffsetXshadowOffsetY 一起设置图形的阴影效果。

示例:

{
    shadowColor: 'rgba(0, 0, 0, 0.5)',
    shadowBlur: 10
}
 dataZoom-slider.moveHandleStyle. shadowColor 试一试

Color

阴影颜色。支持的格式同color

 dataZoom-slider.moveHandleStyle. shadowOffsetX 试一试

number

阴影水平方向上的偏移距离。

 dataZoom-slider.moveHandleStyle. shadowOffsetY 试一试

number

阴影垂直方向上的偏移距离。

 dataZoom-slider.moveHandleStyle. opacity = 0.7 试一试

number

图形透明度。支持从 0 到 1 的数字,为 0 时不绘制该图形。

dataZoom-slider. labelPrecision = 'auto' 试一试

numberstring

显示label的小数精度。默认根据数据自动决定。

dataZoom-slider. labelFormatter

stringFunction

显示的label的格式化器。

  • 如果为 string,表示模板,例如:aaaa{value}bbbb,其中{value}会被替换为实际的数值。

  • 如果为 Function,表示回调函数,例如:

/**
 * @param {*} value 如果 axis.type 为 'category',则 `value` 为 axis.data 的 index。
 *                  否则 `value` 是当前值。
 * @param {strign} valueStr 内部格式化的结果。
 * @return {string} 返回最终的label内容。
 */
labelFormatter: function (value) {
    return 'aaa' + value + 'bbb';
}
dataZoom-slider. showDetail = true 试一试

boolean

是否显示detail,即拖拽时候显示详细数值信息。

dataZoom-slider. showDataShadow = 'auto' 试一试

string

是否在 dataZoom-silder 组件中显示数据阴影。数据阴影可以简单地反应数据走势。

dataZoom-slider. realtime = true 试一试

boolean

拖动时,是否实时更新系列的视图。如果设置为 false,则只在拖拽结束的时候更新。

 dataZoom-slider. textStyle

Object

 dataZoom-slider.textStyle. color = #333 试一试

Color

dataZoom 文字的颜色。

 dataZoom-slider.textStyle. fontStyle = 'normal' 试一试

string

dataZoom 文字字体的风格。

可选:

  • 'normal'
  • 'italic'
  • 'oblique'
 dataZoom-slider.textStyle. fontWeight = 'normal' 试一试

stringnumber

dataZoom 文字字体的粗细。

可选:

  • 'normal'
  • 'bold'
  • 'bolder'
  • 'lighter'
  • 100 | 200 | 300 | 400...
 dataZoom-slider.textStyle. fontFamily = 'sans-serif' 试一试

string

dataZoom 文字的字体系列。

还可以是 'serif' , 'monospace', 'Arial', 'Courier New', 'Microsoft YaHei', ...

 dataZoom-slider.textStyle. fontSize = 12 试一试

number

dataZoom 文字的字体大小。

 dataZoom-slider.textStyle. lineHeight 试一试

number

行高。

rich 中如果没有设置 lineHeight,则会取父层级的 lineHeight。例如:

{
    lineHeight: 56,
    rich: {
        a: {
            // 没有设置 `lineHeight`,则 `lineHeight` 为 56
        }
    }
}
 dataZoom-slider.textStyle. width 试一试

number

文本显示宽度。

 dataZoom-slider.textStyle. height 试一试

number

文本显示高度。

 dataZoom-slider.textStyle. textBorderColor 试一试

Color

文字本身的描边颜色。

 dataZoom-slider.textStyle. textBorderWidth 试一试

number

文字本身的描边宽度。

 dataZoom-slider.textStyle. textBorderType = 'solid' 试一试

stringnumberArray

文字本身的描边类型。

可选:

  • 'solid'
  • 'dashed'
  • 'dotted'

自 v5.0.0 开始,也可以是 number 或者 number 数组,用以指定线条的 dash array,配合 textBorderDashOffset 可实现更灵活的虚线效果。

例如:

{

textBorderType: [5, 10],

textBorderDashOffset: 5
}
 dataZoom-slider.textStyle. textBorderDashOffset 试一试

number

从 v5.0.0 开始支持

用于设置虚线的偏移量,可搭配 textBorderType 指定 dash array 实现灵活的虚线效果。

更多详情可以参考 MDN lineDashOffset。

 dataZoom-slider.textStyle. textShadowColor = 'transparent' 试一试

Color

文字本身的阴影颜色。

 dataZoom-slider.textStyle. textShadowBlur 试一试

number

文字本身的阴影长度。

 dataZoom-slider.textStyle. textShadowOffsetX 试一试

number

文字本身的阴影 X 偏移。

 dataZoom-slider.textStyle. textShadowOffsetY 试一试

number

文字本身的阴影 Y 偏移。

 dataZoom-slider.textStyle. overflow = 'none' 试一试

string

文字超出宽度是否截断或者换行。配置width时有效

  • 'truncate' 截断,并在末尾显示ellipsis配置的文本,默认为...
  • 'break' 换行
  • 'breakAll' 换行,跟'break'不同的是,在英语等拉丁文中,'breakAll'还会强制单词内换行
 dataZoom-slider.textStyle. ellipsis = '...'

string

overflow配置为'truncate'的时候,可以通过该属性配置末尾显示的文本。

dataZoom-slider. xAxisIndex

numberArray

设置 dataZoom-slider 组件控制的 x轴(即xAxis,是直角坐标系中的概念,参见 grid)。

不指定时,当 dataZoom-slider.orient 为 'horizontal'时,默认控制和 dataZoom 平行的第一个 xAxis。但是不建议使用默认值,建议显式指定。

如果是 number 表示控制一个轴,如果是 Array 表示控制多个轴。

例如有如下 ECharts option:

option: {
    xAxis: [
        {...}, // 第一个 xAxis
        {...}, // 第二个 xAxis
        {...}, // 第三个 xAxis
        {...}  // 第四个 xAxis
    ],
    dataZoom: [
        { // 第一个 dataZoom 组件
            xAxisIndex: [0, 2] // 表示这个 dataZoom 组件控制 第一个 和 第三个 xAxis
        },
        { // 第二个 dataZoom 组件
            xAxisIndex: 3      // 表示这个 dataZoom 组件控制 第四个 xAxis
        }
    ]
}
dataZoom-slider. yAxisIndex

numberArray

设置 dataZoom-slider 组件控制的 y轴(即yAxis,是直角坐标系中的概念,参见 grid)。

不指定时,当 dataZoom-slider.orient 为 'vertical'时,默认控制和 dataZoom 平行的第一个 yAxis。但是不建议使用默认值,建议显式指定。

如果是 number 表示控制一个轴,如果是 Array 表示控制多个轴。

例如有如下 ECharts option:

option: {
    yAxis: [
        {...}, // 第一个 yAxis
        {...}, // 第二个 yAxis
        {...}, // 第三个 yAxis
        {...}  // 第四个 yAxis
    ],
    dataZoom: [
        { // 第一个 dataZoom 组件
            yAxisIndex: [0, 2] // 表示这个 dataZoom 组件控制 第一个 和 第三个 yAxis
        },
        { // 第二个 dataZoom 组件
            yAxisIndex: 3      // 表示这个 dataZoom 组件控制 第四个 yAxis
        }
    ]
}
dataZoom-slider. radiusAxisIndex

numberArray

设置 dataZoom-slider 组件控制的 radius 轴(即radiusAxis,是直角坐标系中的概念,参见 polar)。

如果是 number 表示控制一个轴,如果是 Array 表示控制多个轴。

例如有如下 ECharts option:

option: {
    radiusAxis: [
        {...}, // 第一个 radiusAxis
        {...}, // 第二个 radiusAxis
        {...}, // 第三个 radiusAxis
        {...}  // 第四个 radiusAxis
    ],
    dataZoom: [
        { // 第一个 dataZoom 组件
            radiusAxisIndex: [0, 2] // 表示这个 dataZoom 组件控制 第一个 和 第三个 radiusAxis
        },
        { // 第二个 dataZoom 组件
            radiusAxisIndex: 3      // 表示这个 dataZoom 组件控制 第四个 radiusAxis
        }
    ]
}
dataZoom-slider. angleAxisIndex

numberArray

设置 dataZoom-slider 组件控制的 angle 轴(即angleAxis,是直角坐标系中的概念,参见 polar)。

如果是 number 表示控制一个轴,如果是 Array 表示控制多个轴。

例如有如下 ECharts option:

option: {
    angleAxis: [
        {...}, // 第一个 angleAxis
        {...}, // 第二个 angleAxis
        {...}, // 第三个 angleAxis
        {...}  // 第四个 angleAxis
    ],
    dataZoom: [
        { // 第一个 dataZoom 组件
            angleAxisIndex: [0, 2] // 表示这个 dataZoom 组件控制 第一个 和 第三个 angleAxis
        },
        { // 第二个 dataZoom 组件
            angleAxisIndex: 3      // 表示这个 dataZoom 组件控制 第四个 angleAxis
        }
    ]
}
dataZoom-slider. filterMode = 'filter' 试一试

string

dataZoom 的运行原理是通过 数据过滤 以及在内部设置轴的显示窗口来达到 数据窗口缩放 的效果。

数据过滤模式(dataZoom.filterMode)的设置不同,效果也不同。

可选值为:

  • 'filter':当前数据窗口外的数据,被 过滤掉。即  影响其他轴的数据范围。每个数据项,只要有一个维度在数据窗口外,整个数据项就会被过滤掉。

  • 'weakFilter':当前数据窗口外的数据,被 过滤掉。即  影响其他轴的数据范围。每个数据项,只有当全部维度都在数据窗口同侧外部,整个数据项才会被过滤掉。

  • 'empty':当前数据窗口外的数据,被 设置为空。即 不会 影响其他轴的数据范围。

  • 'none': 不过滤数据,只改变数轴范围。

如何设置,由用户根据场景和需求自己决定。经验来说:

  • 当『只有 X 轴 或 只有 Y 轴受 dataZoom 组件控制』时,常使用 filterMode: 'filter',这样能使另一个轴自适应过滤后的数值范围。

  • 当『X 轴 Y 轴分别受 dataZoom 组件控制』时:

    • 如果 X 轴和 Y 轴是『同等地位的、不应互相影响的』,比如在『双数值轴散点图』中,那么两个轴可都设为 filterMode: 'empty'

    • 如果 X 轴为主,Y 轴为辅,比如在『柱状图』中,需要『拖动 dataZoomX 改变 X 轴过滤柱子时,Y 轴的范围也自适应剩余柱子的高度』,『拖动 dataZoomY 改变 Y 轴过滤柱子时,X 轴范围不受影响』,那么就 X轴设为 filterMode: 'filter',Y 轴设为 filterMode: 'empty',即主轴 'filter',辅轴 'empty'

下面是个具体例子:

option = {
    dataZoom: [
        {
            id: 'dataZoomX',
            type: 'slider',
            xAxisIndex: [0],
            filterMode: 'filter'
        },
        {
            id: 'dataZoomY',
            type: 'slider',
            yAxisIndex: [0],
            filterMode: 'empty'
        }
    ],
    xAxis: {type: 'value'},
    yAxis: {type: 'value'},
    series{
        type: 'bar',
        data: [
            // 第一列对应 X 轴,第二列对应 Y 轴。
            [12, 24, 36],
            [90, 80, 70],
            [3, 9, 27],
            [1, 11, 111]
        ]
    }
}

上例中,dataZoomX 的 filterMode 设置为 'filter'。于是,假设当用户拖拽 dataZoomX(不去动 dataZoomY)导致其 valueWindow 变为 [2, 50] 时,dataZoomX 对 series.data 的第一列进行遍历,窗口外的整项去掉,最终得到的 series.data 为:

[
    // 第一列对应 X 轴,第二列对应 Y 轴。
    [12, 24, 36],
    // [90, 80, 70] 整项被过滤掉,因为 90 在 dataWindow 之外。
    [3, 9, 27]
    // [1, 11, 111] 整项被过滤掉,因为 1 在 dataWindow 之外。
]

过滤前,series.data 中对应 Y 轴的值有 2480911,过滤后,只剩下 24 和 9,那么 Y 轴的显示范围就会自动改变以适应剩下的这两个值的显示(如果 Y 轴没有被设置 minmax 固定其显示范围的话)。

所以,filterMode: 'filter' 的效果是:过滤数据后使另外的轴也能自动适应当前数据的范围。

再从头来,上例中 dataZoomY 的 filterMode 设置为 'empty'。于是,假设当用户拖拽 dataZoomY(不去动 dataZoomX)导致其 dataWindow 变为 [10, 60] 时,dataZoomY 对 series.data 的第二列进行遍历,窗口外的值被设置为 empty (即替换为 NaN,这样设置为空的项,其所对应柱形,在 X 轴还有占位,只是不显示出来)。最终得到的 series.data 为:

[
    // 第一列对应 X 轴,第二列对应 Y 轴。
    [12, 24, 36],
    [90, NaN, 70], // 设置为 empty (NaN)
    [3, NaN, 27],  // 设置为 empty (NaN)
    [1, 11, 111]
]

这时,series.data 中对应于 X 轴的值仍然全部保留不受影响,为 129031。那么用户对 dataZoomY 的拖拽操作不会影响到 X 轴的范围。这样的效果,对于离群点(outlier)过滤功能,比较清晰。

如下面的例子:

dataZoom-slider. start 试一试

number

数据窗口范围的起始百分比。范围是:0 ~ 100。表示 0% ~ 100%。

dataZoom-slider.start 和 dataZoom-slider.end 共同用 百分比 的形式定义了数据窗口范围。

关于坐标轴范围(axis extent)和 dataZoom-slider.start 的关系的更多信息,请参见:dataZoom-slider.rangeMode。

dataZoom-slider. end = 100 试一试

number

数据窗口范围的结束百分比。范围是:0 ~ 100。

dataZoom-slider.start 和 dataZoom-slider.end 共同用 百分比 的形式定义了数据窗口范围。

关于坐标轴范围(axis extent)和 dataZoom-slider.end 的关系的更多信息,请参见:dataZoom-slider.rangeMode。

dataZoom-slider. startValue

numberstringDate

数据窗口范围的起始数值。如果设置了 dataZoom-slider.start 则 startValue 失效。

dataZoom-slider.startValue 和 dataZoom-slider.endValue 共同用 绝对数值 的形式定义了数据窗口范围。

注意,如果轴的类型为 category,则 startValue 既可以设置为 axis.data 数组的 index,也可以设置为数组值本身。 但是如果设置为数组值本身,会在内部自动转化为数组的 index。

关于坐标轴范围(axis extent)和 dataZoom-slider.startValue 的关系的更多信息,请参见:dataZoom-slider.rangeMode。

dataZoom-slider. endValue

numberstringDate

数据窗口范围的结束数值。如果设置了 dataZoom-slider.end 则 endValue 失效。

dataZoom-slider.startValue 和 dataZoom-slider.endValue 共同用 绝对数值 的形式定义了数据窗口范围。

注意,如果轴的类型为 category,则 endValue 即可以设置为 axis.data 数组的 index,也可以设置为数组值本身。 但是如果设置为数组值本身,会在内部自动转化为数组的 index。

关于坐标轴范围(axis extent)和 dataZoom-slider.endValue 的关系的更多信息,请参见:dataZoom-slider.rangeMode。

dataZoom-slider. minSpan 试一试

number

用于限制窗口大小的最小值(百分比值),取值范围是 0 ~ 100

如果设置了 dataZoom-slider.minValueSpan 则 minSpan 失效。

dataZoom-slider. maxSpan 试一试

number

用于限制窗口大小的最大值(百分比值),取值范围是 0 ~ 100

如果设置了 dataZoom-slider.maxValueSpan 则 maxSpan 失效。

dataZoom-slider. minValueSpan

numberstringDate

用于限制窗口大小的最小值(实际数值)。

如在时间轴上可以设置为:3600 * 24 * 1000 * 5 表示 5 天。 在类目轴上可以设置为 5 表示 5 个类目。

dataZoom-slider. maxValueSpan

numberstringDate

用于限制窗口大小的最大值(实际数值)。

如在时间轴上可以设置为:3600 * 24 * 1000 * 5 表示 5 天。 在类目轴上可以设置为 5 表示 5 个类目。

dataZoom-slider. orient 试一试

string

布局方式是横还是竖。不仅是布局方式,对于直角坐标系而言,也决定了,缺省情况控制横向数轴还是纵向数轴。

可选值为:

  • 'horizontal':水平。

  • 'vertical':竖直。

dataZoom-slider. zoomLock 试一试

boolean

是否锁定选择区域(或叫做数据窗口)的大小。

如果设置为 true 则锁定选择区域的大小,也就是说,只能平移,不能缩放。

dataZoom-slider. throttle = 100 试一试

number

设置触发视图刷新的频率。单位为毫秒(ms)。

如果 animation 设为 true 且 animationDurationUpdate 大于 0,可以保持 throttle 为默认值 100(或者设置为大于 0 的值),否则拖拽时有可能画面感觉卡顿。

如果 animation 设为 false 或者 animationDurationUpdate 设为 0,且在数据量不大时,拖拽时画面感觉卡顿,可以把尝试把 throttle 设为 0 来改善。

dataZoom-slider. rangeMode

Array

形式为:[rangeModeForStart, rangeModeForEnd]

例如 rangeMode: ['value', 'percent'],表示 start 值取绝对数值,end 取百分比。

每项可选值为:'value''percent'

  • 'value' 模式:处于此模式下,坐标轴范围(axis extent)总只会被dataZoom.startValue and dataZoom.endValue 决定,而不管数据是多少,以及不管,axis.min 和 axis.max 怎么设置。
  • 'percent' 模式:处于此模式下,100 代表 100% 的 [dMin, dMax]。这里 dMin 表示,如果 axis.min 设置了就是 axis.min,否则是 data.extent[0]dMax 表示,如果 axis.max 设置了就是 axis.max,否则是 data.extent[1][dMin, dMax] 乘以 percent 的结果得到坐标轴范围(axis extent)。

默认情况下,rangeMode 总是被自动设定。如果指定了 option.start/option.end 那么就设定为 'percent',如果指定了 option.startValue/option.endValue 那么就设定为 'value'。以及当用户用不用操作触发视图改变时,rangeMode 也可能会相应得变化(如,通过 toolbox.dataZoom 触发视图改变时,rangeMode 会自动被设置为 value,通过 dataZoom-inside 和 dataZoom-slider 触发视图改变时,会自动被设置为 'percent')。

如果我们手动在 option 中设定了 rangeMode,那么它只在 start 和 startValue 都设置了或者 end 和 endValue 都设置了才有意义。所以通常我们没必要在 option 中指定 rangeMode

举例一个使用场景:当我们使用动态数据时(即,周期性得通过 setOption 来改变数据),如果 rangeMode 在 'value' 模式,dataZoom 的窗口会一直保持在一个固定的值区间,无论数据怎么改变添加了多少;如果 rangeMode 在 'percent' 模式,窗口会随着数据的添加而改变(假设 axis.min 和 axis.max 没有被设置)。

dataZoom-slider. zlevel

number

所有图形的 zlevel 值。

zlevel用于 Canvas 分层,不同zlevel值的图形会放置在不同的 Canvas 中,Canvas 分层是一种常见的优化手段。我们可以把一些图形变化频繁(例如有动画)的组件设置成一个单独的zlevel。需要注意的是过多的 Canvas 会引起内存开销的增大,在手机端上需要谨慎使用以防崩溃。

zlevel 大的 Canvas 会放在 zlevel 小的 Canvas 的上面。

dataZoom-slider. z = 2

number

组件的所有图形的z值。控制图形的前后顺序。z值小的图形会被z值大的图形覆盖。

z相比zlevel优先级更低,而且不会创建新的 Canvas。

dataZoom-slider. left = 'auto' 试一试

stringnumber

dataZoom-slider组件离容器左侧的距离。

left 的值可以是像 20 这样的具体像素值,可以是像 '20%' 这样相对于容器高宽的百分比,也可以是 'left''center''right'

如果 left 的值为 'left''center''right',组件会根据相应的位置自动对齐。

dataZoom-slider. top = 'auto' 试一试

stringnumber

dataZoom-slider组件离容器上侧的距离。

top 的值可以是像 20 这样的具体像素值,可以是像 '20%' 这样相对于容器高宽的百分比,也可以是 'top''middle''bottom'

如果 top 的值为 'top''middle''bottom',组件会根据相应的位置自动对齐。

dataZoom-slider. right = 'auto' 试一试

stringnumber

dataZoom-slider组件离容器右侧的距离。

right 的值可以是像 20 这样的具体像素值,可以是像 '20%' 这样相对于容器高宽的百分比。

默认自适应。

dataZoom-slider. bottom = 'auto' 试一试

stringnumber

dataZoom-slider组件离容器下侧的距离。

bottom 的值可以是像 20 这样的具体像素值,可以是像 '20%' 这样相对于容器高宽的百分比。

默认自适应。

dataZoom-slider. width 试一试

stringnumber

dataZoom-slider 组件的宽度。竖直布局默认 30,水平布局默认自适应。

比 left 和 right 优先级高。

dataZoom-slider. height 试一试

stringnumber

dataZoom-slider 组件的高度。水平布局默认 30,竖直布局默认自适应。

比 top 和 bottom 优先级高。

dataZoom-slider. brushSelect = true

boolean

从 v5.0.0 开始支持

是否开启刷选功能。在下图的 brush 区域你可以按住鼠标左键后框选出选中部分。

 dataZoom-slider. brushStyle

Object

从 v5.0.0 开始支持

刷选框样式设置。

 dataZoom-slider.brushStyle. color = rgba(135,175,274,0.15) 试一试

Color

图形的颜色。

支持使用rgb(255,255,255)rgba(255,255,255,1)#fff等方式设置为纯色,也支持设置为渐变色和纹理填充,具体见option.color

 dataZoom-slider.brushStyle. borderColor = '#000' 试一试

Color

图形的描边颜色。支持的颜色格式同 color,不支持回调函数。

 dataZoom-slider.brushStyle. borderWidth 试一试

number

描边线宽。为 0 时无描边。

 dataZoom-slider.brushStyle. borderType = 'solid' 试一试

stringnumberArray

描边类型。

可选:

  • 'solid'
  • 'dashed'
  • 'dotted'

自 v5.0.0 开始,也可以是 number 或者 number 数组,用以指定线条的 dash array,配合 borderDashOffset 可实现更灵活的虚线效果。

例如:

{

borderType: [5, 10],

borderDashOffset: 5
}
 dataZoom-slider.brushStyle. borderDashOffset 试一试

number

从 v5.0.0 开始支持

用于设置虚线的偏移量,可搭配 borderType 指定 dash array 实现灵活的虚线效果。

更多详情可以参考 MDN lineDashOffset。

 dataZoom-slider.brushStyle. borderCap = 'butt' 试一试

string

从 v5.0.0 开始支持

用于指定线段末端的绘制方式,可以是:

  • 'butt': 线段末端以方形结束。
  • 'round': 线段末端以圆形结束。
  • 'square': 线段末端以方形结束,但是增加了一个宽度和线段相同,高度是线段厚度一半的矩形区域。

默认值为 'butt'。 更多详情可以参考 MDN lineCap。

 dataZoom-slider.brushStyle. borderJoin = 'bevel' 试一试

string

从 v5.0.0 开始支持

用于设置2个长度不为0的相连部分(线段,圆弧,曲线)如何连接在一起的属性(长度为0的变形部分,其指定的末端和控制点在同一位置,会被忽略)。

可以是:

  • 'bevel': 在相连部分的末端填充一个额外的以三角形为底的区域, 每个部分都有各自独立的矩形拐角。
  • 'round': 通过填充一个额外的,圆心在相连部分末端的扇形,绘制拐角的形状。 圆角的半径是线段的宽度。
  • 'miter': 通过延伸相连部分的外边缘,使其相交于一点,形成一个额外的菱形区域。这个设置可以通过 borderMiterLimit 属性看到效果。

默认值为 'bevel'。 更多详情可以参考 MDN lineJoin。

 dataZoom-slider.brushStyle. borderMiterLimit = 10 试一试

number

从 v5.0.0 开始支持

用于设置斜接面限制比例。只有当 borderJoin 为 miter 时, borderMiterLimit 才有效。

默认值为 10。负数、0Infinity 和 NaN 均会被忽略。

更多详情可以参考 MDN miterLimit。

 dataZoom-slider.brushStyle. shadowBlur 试一试

number

图形阴影的模糊大小。该属性配合 shadowColor,shadowOffsetXshadowOffsetY 一起设置图形的阴影效果。

示例:

{
    shadowColor: 'rgba(0, 0, 0, 0.5)',
    shadowBlur: 10
}
 dataZoom-slider.brushStyle. shadowColor 试一试

Color

阴影颜色。支持的格式同color

 dataZoom-slider.brushStyle. shadowOffsetX 试一试

number

阴影水平方向上的偏移距离。

 dataZoom-slider.brushStyle. shadowOffsetY 试一试

number

阴影垂直方向上的偏移距离。

 dataZoom-slider.brushStyle. opacity = 1 试一试

number

图形透明度。支持从 0 到 1 的数字,为 0 时不绘制该图形。

 dataZoom-slider. emphasis

Object

从 v5.0.0 开始支持

高亮样式设置。

  dataZoom-slider.emphasis. handleStyle

Object

所有属性

{ color , borderColor , borderWidth , borderType , borderDashOffset , borderCap , borderJoin , borderMiterLimit , shadowBlur , shadowColor , shadowOffsetX , shadowOffsetY , opacity }

  dataZoom-slider.emphasis. moveHandleStyle

Object

 dataZoom-slider.emphasis.moveHandleStyle. color = 自适应 试一试

Color

图形的颜色。

支持使用rgb(255,255,255)rgba(255,255,255,1)#fff等方式设置为纯色,也支持设置为渐变色和纹理填充,具体见option.color

 dataZoom-slider.emphasis.moveHandleStyle. borderColor = '#000' 试一试

Color

图形的描边颜色。支持的颜色格式同 color,不支持回调函数。

 dataZoom-slider.emphasis.moveHandleStyle. borderWidth 试一试

number

描边线宽。为 0 时无描边。

 dataZoom-slider.emphasis.moveHandleStyle. borderType = 'solid' 试一试

stringnumberArray

描边类型。

可选:

  • 'solid'
  • 'dashed'
  • 'dotted'

自 v5.0.0 开始,也可以是 number 或者 number 数组,用以指定线条的 dash array,配合 borderDashOffset 可实现更灵活的虚线效果。

例如:

{

borderType: [5, 10],

borderDashOffset: 5
}
 dataZoom-slider.emphasis.moveHandleStyle. borderDashOffset 试一试

number

从 v5.0.0 开始支持

用于设置虚线的偏移量,可搭配 borderType 指定 dash array 实现灵活的虚线效果。

更多详情可以参考 MDN lineDashOffset。

 dataZoom-slider.emphasis.moveHandleStyle. borderCap = 'butt' 试一试

string

从 v5.0.0 开始支持

用于指定线段末端的绘制方式,可以是:

  • 'butt': 线段末端以方形结束。
  • 'round': 线段末端以圆形结束。
  • 'square': 线段末端以方形结束,但是增加了一个宽度和线段相同,高度是线段厚度一半的矩形区域。

默认值为 'butt'。 更多详情可以参考 MDN lineCap。

 dataZoom-slider.emphasis.moveHandleStyle. borderJoin = 'bevel' 试一试

string

从 v5.0.0 开始支持

用于设置2个长度不为0的相连部分(线段,圆弧,曲线)如何连接在一起的属性(长度为0的变形部分,其指定的末端和控制点在同一位置,会被忽略)。

可以是:

  • 'bevel': 在相连部分的末端填充一个额外的以三角形为底的区域, 每个部分都有各自独立的矩形拐角。
  • 'round': 通过填充一个额外的,圆心在相连部分末端的扇形,绘制拐角的形状。 圆角的半径是线段的宽度。
  • 'miter': 通过延伸相连部分的外边缘,使其相交于一点,形成一个额外的菱形区域。这个设置可以通过 borderMiterLimit 属性看到效果。

默认值为 'bevel'。 更多详情可以参考 MDN lineJoin。

 dataZoom-slider.emphasis.moveHandleStyle. borderMiterLimit = 10 试一试

number

从 v5.0.0 开始支持

用于设置斜接面限制比例。只有当 borderJoin 为 miter 时, borderMiterLimit 才有效。

默认值为 10。负数、0Infinity 和 NaN 均会被忽略。

更多详情可以参考 MDN miterLimit。

 dataZoom-slider.emphasis.moveHandleStyle. shadowBlur 试一试

number

图形阴影的模糊大小。该属性配合 shadowColor,shadowOffsetXshadowOffsetY 一起设置图形的阴影效果。

示例:

{
    shadowColor: 'rgba(0, 0, 0, 0.5)',
    shadowBlur: 10
}
 dataZoom-slider.emphasis.moveHandleStyle. shadowColor 试一试

Color

阴影颜色。支持的格式同color

 dataZoom-slider.emphasis.moveHandleStyle. shadowOffsetX 试一试

number

阴影水平方向上的偏移距离。

 dataZoom-slider.emphasis.moveHandleStyle. shadowOffsetY 试一试

number

阴影垂直方向上的偏移距离。

 dataZoom-slider.emphasis.moveHandleStyle. opacity  = 1 试一试

number

图形透明度。支持从 0 到 1 的数字,为 0 时不绘制该图形。

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

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

相关文章

牛客小白月赛103(打表、二进制、几何、思维)

文章目录 牛客小白月赛103(打表、二进制、几何、思维)A. 小冰的正多边形B. 冰冰的电子邮箱C. 冰冰的异或(打表、二进制)D. 冰冰的分界线(几何、浮点数处理)E. 冰冰的 GCD(调和级数、思维) 据说F是假题&…

「C/C++」C++17 之 std::variant 安全的联合体(变体)

#1024程序员节|征文# ✨博客主页何曾参静谧的博客📌文章专栏「C/C」C/C程序设计📚全部专栏「VS」Visual Studio「C/C」C/C程序设计「UG/NX」BlockUI集合「Win」Windows程序设计「DSA」数据结构与算法「UG/NX」NX二次开发「QT」QT5程序设计…

Web3的去中心化社交网络:区块链技术如何改变互动方式

随着互联网技术的不断进步,社交网络正在经历一场深刻的变革。Web3,作为新一代互联网技术的代表,正通过区块链和去中心化理念改变着我们与他人互动的方式。传统的社交网络通常由大型公司控制,用户数据的集中化管理和隐私问题备受关…

代码随想录(十二)——图论

并查集 并查集主要有三个功能。 寻找根节点,函数:find(int u),也就是判断这个节点的祖先节点是哪个将两个节点接入到同一个集合,函数:join(int u, int v),将两个节点连在同一个根节点上判断两个节点是否在…

HarmonyOS 5.0应用开发——文件读写

【高心星出品】 文章目录 文件读写文件操作创建目录删除目录或者文件扫描目录中文件 文本读写写入文本读取文本内容 文件读写文件写入边读边写 文件读写 Core File Kit(文件基础服务)为开发者提供一套访问和管理应用文件和用户文件的能力。帮助用户更高…

44-RK3588s调试 camera-engine-rkaiq(rkaiq_3A_server)

在RK3588s平台上调试imx415 camera sensor 过程中,已经识别到了camera sensor ID,并且可以拿到raw图和isp处理后的图像,但是isp处理后的图像偏绿,来看查看后台服务发现rkaiq_3A_server没有运行,然后单独运行rkaiq_3A_s…

Linux 宝塔安装(各操作系统命令合集)

由于CentOS官方已全面停止维护CentOS Linux项目,公告指出 CentOS 7和8在2024年6月30日停止技术服务支持,详情见CentOS官方公告。导致CentOS系统源已全面失效,比如安装宝塔等等会出现网络不可达等报错,需要切换源。系统源问题&…

Android 获取OAID

获取OAID 老规矩,直接上: implementation com.huawei.hms:opendevice:6.11.0.300 // 要获取华为vaid 和aaid,还需添加opendevice 依赖implementation(name: oaid_sdk_2.5.0, ext: aar) import android.content.Context; import android.util.…

基于微信小程序的公务员考试信息查询系统+LW示例参考

系列文章目录 1.基于SSM的洗衣房管理系统原生微信小程序LW参考示例 2.基于SpringBoot的宠物摄影网站管理系统LW参考示例 3.基于SpringBootVue的企业人事管理系统LW参考示例 4.基于SSM的高校实验室管理系统LW参考示例 5.基于SpringBoot的二手数码回收系统原生微信小程序LW参考示…

【Android】Kotlin教程(4)

文章目录 1.field2.计算属性3.主构造函数4.次构造函数5.默认参数6.初始化块7.初始化顺序7.延迟初始化lateinit8.惰性初始化 1.field field 关键字通常与属性的自定义 getter 和 setter 一起使用。当你需要为一个属性提供自定义的行为时,可以使用 field 来访问或设置…

可以在线制作的PS网页版来了!

在当今数字化的创意时代,设计领域不断发展与变革,设计师们对于工具的需求也日益多样化和高效化。随着互联网技术的飞速进步,一种全新的设计工具模式应运而生——在线制作的 PS 网页版。它以其独特的优势和便捷性,逐渐成为众多设计…

高德地图如何添加自己店铺的位置信息?

众所周知,创业开店时,地理位置的选择至关重要。一个优越的地理位置不仅能显著提升店铺的可见度,还能有效吸引更多潜在顾客的光顾。而且,为了将店铺的客流量最大化,商家还需在地图平台上准确标注自己的位置信息&#xf…

【黄豆颗粒数据集】黄豆识别 机器视觉 深度学习(含数据集)

一、背景意义 随着全球农业生产的现代化,黄豆(大豆)作为一种重要的经济作物,广泛用于食品、饲料和工业原料的生产。准确识别和分类黄豆颗粒对于农业生产的管理、质量控制和市场分析具有重要意义。然而,传统的人工分类方…

JavaEE-多线程上

文章目录 线程概述进程/线程多线程的作用JVM关于线程资源的规范关于Java程序的运行原理 并发与并行并发(concurrency)并行(parallellism)并发编程与并行编程 线程的调度策略分时调度模型抢占式调度模型 创建线程线程类分析入门实现线程的第一种方式实现线程的第二种方式 线程的…

论文阅读:三星-TinyClick

《Single-Turn Agent for Empowering GUI Automation》 赋能GUI自动化的单轮代理 摘要 我们介绍了一个用于图形用户界面(GUI)交互任务的单轮代理,使用了视觉语言模型Florence-2-Base。该代理的主要任务是识别与用户指令相对应的UI元素的屏幕…

Tomcat servlet response关于中文乱码的经验

前言 最近修改老项目项目,使用zuul网关返回的中文内容乱码了,如果使用GBK或者GB2312编码确正常显示,稍微实验了一下,发现里面很多细节,毕竟Springboot对我们做了很多事情,而且当我们使用不同的模式会出现很…

服务器的免密登录和文件传输

在天文学研究中,通常会采用ssh登录服务器,把复杂的计算交给服务器,但是如果你没有进行额外的配置,那么登录服务器,以及和服务器进行文件传输,每次都要输入账号和密码,比较不方便,Win…

Windows Server NTFS磁盘变RAM的处理过程

问题描述 客户服务器的磁盘数据爆满,需要将磁盘进行扩容,因为是虚拟机所以先在虚拟化平台上将原来的磁盘空间改大,再进入系统,在磁盘管理器上将需要扩容的磁盘进行扩展。扩展完后系统报文件系统有问题,扩容的磁盘容量…

No.23 笔记 | WEB安全 - 任意文件漏洞 part 5

本文全面且深入地探讨了文件上传漏洞相关知识。从基础概念出发,清晰地阐述了文件上传漏洞的定义及其产生的本质原因,同时列出了该漏洞成立的必要条件。详细说明了文件上传漏洞可能对服务器控制权、网站安全以及业务运营带来的严重危害。 文中还深入解析了…

[mysql]子查询的概述和分类及单行子查询

子查询引入 查询的基本结构已经给大家了,子查询里面也是有一些新的内容,子查询其实就是在查询中嵌套另一个查询,叫嵌套查询可能大家更容易理解一点..,类似与FOR循环和FOR循环的嵌套,这一章是我们查询的最难的部分,大家 难度是查询的顶峰,多表查询和子查询是非常重要,SQL优化里…