文字高亮 render

vue 文字高亮 render

.vue

// 返回位置

function customPosition(value = '', key = '', length = 0) {
    if (value.length === 0 || key.length === 0) {
        return []
    }
    const index = value.indexOf(key)
    if (index > -1) {
        return [index + length].concat(customPosition(value.substr(index + key.length), key, length + index + key.length))
    }
    return []
}

function customDom(h, { value = '', keyword = '' }) {
    if (value === '') {
        return h('div', {}, [h('span', {}, '')])
    }
    if (keyword === '') {
        return h('div', {}, [h('span', {}, value)])
    }
    const positionArr = customPosition(value, keyword);
    const arrDom = [];
    if (positionArr.length > 0) {
        let length = 0;
        positionArr.forEach(key => {
            arrDom.push(h('span', {}, value.substring(length, key)))
            arrDom.push(h('span', { staticClass: 'custom-keyword' }, value.substring(key, key + keyword.length)))
            length = key + keyword.length;
        })
        arrDom.push(h('span', {}, value.substring(length)))
    } else {
        arrDom.push(h('span', {}, value))
    }
    return h('div', {}, arrDom)
}

export default {
    name: 'JsonExpand',
    functional: true,
    props: {
        value: {
            type: String,
            default: ''
        },
        keyword: {
            type: String,
            default: ''
        }
    },
    render: (h, ctx) => {
        const value = ctx.props.value;
        const keyword = ctx.props.keyword;
        return customDom(h, { value, keyword })
    }
};
// 根据关键词拆分

function customDom(h, { value = '', keyword = '' }) {
    if (value === '') {
        return h('div', {}, [h('span', {}, '')])
    }
    if (keyword === '') {
        return h('div', {}, [h('span', {}, value)])
    }
    const valueArr = value.split(keyword);
    const arrDom = [];
    valueArr.forEach(item => {
        if (item !== '') {
            arrDom.push(h('span', { staticClass: 'custom-normal' }, item))
            arrDom.push(h('span', { staticClass: 'custom-keyword' }, keyword))
        } else {
            arrDom.push(h('span', { staticClass: 'custom-keyword' }, keyword))
        }
    })
    arrDom.pop()
    return h('div', {}, arrDom)
}

export default {
    name: 'JsonExpand',
    functional: true,
    props: {
        value: {
            type: String,
            default: ''
        },
        keyword: {
            type: String,
            default: ''
        }
    },
    render: (h, ctx) => {
        const value = ctx.props.value;
        const keyword = ctx.props.keyword;
        return customDom(h, { value, keyword })
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要在pyecharts中实现文字高亮,可以使用echarts中的rich文本标签。具体步骤如下: 1. 安装pyecharts和echarts ```python pip install pyecharts pip install echarts ``` 2. 导入必要的库 ```python from pyecharts import options as opts from pyecharts.charts import Bar, Line from pyecharts.commons.utils import JsCode from pyecharts.globals import ThemeType ``` 3. 创建Bar或Line图表对象,并设置标题、x轴数据、y轴数据 ```python bar = Bar(init_opts=opts.InitOpts(theme=ThemeType.LIGHT)) bar.set_global_opts(title_opts=opts.TitleOpts(title="柱状图")) bar.add_xaxis(["A", "B", "C", "D", "E"]) bar.add_yaxis("数量", [10, 20, 30, 40, 50]) ``` 4. 使用rich文本标签设置需要高亮文字 ```python bar.set_series_opts( label_opts=opts.LabelOpts( formatter=JsCode( """ function(params) { return `{a|${params.name}}\n{b|${params.value}}`; } """ ), rich={ "a": {"color": "red", "fontSize": 16}, "b": {"color": "blue", "fontSize": 12}, }, ) ) ``` 在上述代码中,我们使用了rich属性,它是一个字典类型,用于设置富文本样式。其中,a和b是富文本标签的名称,可以自定义,color和fontSize分别表示字体颜色和字体大小。在formatter函数中,我们使用了ES6模板字符串的语法,在字符串中使用${}包含变量名,可以在函数中使用params.name和params.value获取对应的名称和值。 5. 渲染图表 ```python bar.render("bar.html") ``` 完整代码如下: ```python from pyecharts import options as opts from pyecharts.charts import Bar, Line from pyecharts.commons.utils import JsCode from pyecharts.globals import ThemeType bar = Bar(init_opts=opts.InitOpts(theme=ThemeType.LIGHT)) bar.set_global_opts(title_opts=opts.TitleOpts(title="柱状图")) bar.add_xaxis(["A", "B", "C", "D", "E"]) bar.add_yaxis("数量", [10, 20, 30, 40, 50]) bar.set_series_opts( label_opts=opts.LabelOpts( formatter=JsCode( """ function(params) { return `{a|${params.name}}\n{b|${params.value}}`; } """ ), rich={ "a": {"color": "red", "fontSize": 16}, "b": {"color": "blue", "fontSize": 12}, }, ) ) bar.render("bar.html") ``` ### 回答2: 使用pyecharts搭建BI看板,可以通过一些方法实现文字高亮效果。 首先,我们可以使用WordCloud(词云图)来实现文字高亮。词云图是一种将关键词按照出现的频次进行可视化展示的图表,可以通过设置关键词的权重和颜色来实现文字高亮效果。通过设置权重较高的关键词,可以使其在词云图中显示更大和更突出;通过设置关键词的颜色,可以使其与其他关键词形成对比,进一步突出文字高亮效果。 其次,我们还可以使用Bar(柱状图)来实现文字高亮。柱状图通常用于展示分类数据的大小和差异,可以根据数据大小对柱状图进行排序,然后将需要高亮显示的文字对应的柱状图设置为特定的颜色,从而达到文字高亮的效果。 除了以上两种方法,我们还可以根据实际需求,使用其他图表类型来实现文字高亮效果。例如,Pie(饼图)、Line(折线图)等都可以通过调整颜色、标签样式等方式来实现文字高亮效果。 总结来说,基于pyecharts搭建BI看板,我们可以通过调整关键词的权重和颜色、设置柱状图颜色以及调整其他图表的样式等方式来实现文字高亮效果。这些方法的具体实现可以根据具体的需求和数据类型进行调整,以达到最佳的视觉效果。 ### 回答3: 在使用pyecharts搭建BI看板时,可以使用文字高亮功能来突出显示关键信息。 首先,需要导入必要的库和模块,包括pyecharts和pandas。然后,可以创建一个柱状图或折线图等图表,将数据传入其中。接着,可以设置图表的样式和属性,如标题、坐标轴标签等。最后,通过使用highlight_text函数进行文字高亮。 highlight_text函数接收三个参数,分别是图表实例、想要高亮文字高亮的颜色。可以使用set_series_opts方法设置文字的颜色为高亮颜色。 以下是一个使用pyecharts搭建BI看板并进行文字高亮的示例代码: ```python import pandas as pd from pyecharts import options as opts from pyecharts.charts import Bar # 创建柱状图实例 bar = Bar() # 设置柱状图的标题和坐标轴标签 bar.set_global_opts( title_opts=opts.TitleOpts(title="销售额统计"), xaxis_opts=opts.AxisOpts(name="日期"), yaxis_opts=opts.AxisOpts(name="销售额"), ) # 加载数据 data = pd.DataFrame({"日期": ["2020-01-01", "2020-01-02", "2020-01-03"], "销售额": [10000, 15000, 12000]}) # 添加数据到柱状图 bar.add_xaxis(data["日期"].tolist()) bar.add_yaxis("销售额", data["销售额"].tolist()) # 设置文字高亮 highlight_text = "15000" highlight_color = "#FF0000" bar.set_series_opts(label_opts=opts.LabelOpts(color="auto"), markpoint_opts=opts.MarkPointOpts( data=[opts.MarkPointItem(type_="max", name="最大值")])) bar.set_series_opts( label_opts=opts.LabelOpts(formatter="{c}", color="auto", rich={"highlight": {"color": highlight_color}})) # 在标记点处进行文字高亮 bar.set_series_opts( label_opts=opts.LabelOpts(formatter=JsCode( """function(params){ if (params.data === '15000') { return '{highlight|' + params.data + '}'; } return params.data; }"""), rich={"highlight": {"color": highlight_color}} ) ) # 生成HTML文件 bar.render("highlight_bar.html") ``` 以上代码通过设置highlight_text为"15000",将该数据所在的文字高亮显示。其中的highlight_color设为"#FF0000",即红色。这样,在生成的柱状图上,销售额为15000的数据将以红色高亮显示。 通过这种方式,可以利用pyecharts搭建BI看板,并通过文字高亮功能突出显示重要的数据信息,提高信息的传达效果和视觉效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值