highcharts特殊定制:x轴文字竖直显示(兼容各浏览器)
2014-11-08 23:28
239 查看
做项目要用到highcharts画柱状图,可是x轴数据过多,如果文字从左至右显示显得拥挤不堪,于是想竖起显示,于是想到用xAxis的rotation属性,把文字旋转90度,可是这样文字显示虽然是竖直但却是歪的,如图
。于是网上各种关键字各种搜索,一种说法是:在xAxis的labels属性里加样式,即style:{ writingMode:'tb-rl',
//文字竖排样式},或者:style:{layoutFlow: 'vertical-ideographic'},可是两种都只支持ie内核的浏览器,火狐,chrome不支持。于是再次搜索html文字竖直显示关键字,查到如下一段代码:
css样式:
#dy{
font-size: 14px;
width: 14px;
word-wrap: break-word;
display:block;
}
</style>
body:
<text id='dy'>
测试需要垂直显示的文字 T E S T B Y
</text>
测试各种浏览器都可以正常竖直显示,于是应用到highchart,同样在xAxis的lables属性里加样式:即
style:{fontSize: '14px',
width: '14px',
wordWrap: 'breakWord',
display:'block'}
心想,这下肯定有效果了,可是前台一查看,还是没效果。
就这样,隔了一天之后,终于灵机一想:可不可以把x轴上的数据,每个数据的每两个字之间加个换行符<br/>,想到于是立即行动,没想到真的成功了!如下js代码,对x轴数据deptnames数组进行:分别取每个元素,在其每两个字之间加上换行符<br/>,如‘信息科'就转换成:'信<br/>息<br/>科<br/>:
var deptnames1 = new Array(); //deptnames1是用来放置处理后的数组
for(var i = 0; i < deptnames.length;i++){ //deptnames是处理前的数组
var deptname = deptnames[i];
var str = deptname.charAt(0);
for( var j = 1; j < deptname.length; j++){
str = str + '<br/>' + deptname.charAt(j);
}
deptnames1.push(str);
}
效果如图:
于是趁着今天记忆还在,把其记录下来,希望可以帮到别的遇到同样问题的朋友。
。于是网上各种关键字各种搜索,一种说法是:在xAxis的labels属性里加样式,即style:{ writingMode:'tb-rl',
//文字竖排样式},或者:style:{layoutFlow: 'vertical-ideographic'},可是两种都只支持ie内核的浏览器,火狐,chrome不支持。于是再次搜索html文字竖直显示关键字,查到如下一段代码:
css样式:
#dy{
font-size: 14px;
width: 14px;
word-wrap: break-word;
display:block;
}
</style>
body:
<text id='dy'>
测试需要垂直显示的文字 T E S T B Y
</text>
测试各种浏览器都可以正常竖直显示,于是应用到highchart,同样在xAxis的lables属性里加样式:即
style:{fontSize: '14px',
width: '14px',
wordWrap: 'breakWord',
display:'block'}
心想,这下肯定有效果了,可是前台一查看,还是没效果。
就这样,隔了一天之后,终于灵机一想:可不可以把x轴上的数据,每个数据的每两个字之间加个换行符<br/>,想到于是立即行动,没想到真的成功了!如下js代码,对x轴数据deptnames数组进行:分别取每个元素,在其每两个字之间加上换行符<br/>,如‘信息科'就转换成:'信<br/>息<br/>科<br/>:
var deptnames1 = new Array(); //deptnames1是用来放置处理后的数组
for(var i = 0; i < deptnames.length;i++){ //deptnames是处理前的数组
var deptname = deptnames[i];
var str = deptname.charAt(0);
for( var j = 1; j < deptname.length; j++){
str = str + '<br/>' + deptname.charAt(j);
}
deptnames1.push(str);
}
效果如图:
于是趁着今天记忆还在,把其记录下来,希望可以帮到别的遇到同样问题的朋友。
相关文章推荐
- 浏览器兼容问题项目总结(二)Highchart 在chrome下x轴文字竖直显示(兼容IE和Chrome)
- VB实现文字“闪入”显示的特殊效果
- VB实现文字“闪入”显示的特殊效果
- javascript获取选中文字-兼容各浏览器
- CSS实现背景透明,文字不透明(兼容各种浏览器)
- CSS实现背景透明,文字不透明(兼容各浏览器)
- 如何定制日历控件显示的星期文字
- input file文字可修改兼容各浏览器
- css实现【文章未完末尾处的文字颜色变淡效果】兼容常用浏览器
- 兼容所有浏览器的半透明背景且不透明文字的CSS写法
- android 通过canvas旋转 绘制文字 竖直等不同方向的显示
- JS实时显示当前时间(IE+firefox)浏览器兼容代码(图证)
- CSS实现兼容浏览器的文字阴影效果
- iframe显示高度自适应兼容多浏览器
- “如何将16进制码流在html中显示为图片”兼容多个浏览器的方案
- 为了兼容所有的浏览器都可以显示半透明效果的写法
- 如何定制日历控件显示的星期文字
- “如何将16进制码流在html中显示为图片”兼容多个浏览器的方案。
- 浏览器兼容CSS代码:按钮文字垂直居中(input button text vertical align)
- html 超出部分用省略符号显示(兼容浏览器)