在新换的 spfk 主题里的 main.js 中有这样一段代码
{% fold 点击显/隐代码%}```javascript main.js
//是否使用fancybox
if(yiliaConfig.fancybox === true){
require([yiliaConfig.rootUrl + 'fancybox/jquery.fancybox.js'], function(pc){
var isFancy = $(".isFancy");
if(isFancy.length != 0){
var imgArr = $(".article-inner img");
for(var i=0,len=imgArr.length;i<len;i++){
var src = imgArr.eq(i).attr("src");
var title = imgArr.eq(i).attr("alt");
imgArr.eq(i).replaceWith("");
}
$(".article-inner .fancy-ctn").fancybox();
}
});
}
{% endfold %}
很容易明白,这是处理fancybox中,点击放大图片功能的代码
检测到图片后会自动修改 `img` 为 `<a ...><img ...></a>`
<!--more-->
而 spfk 对 a 有单独的 css 样式
因此当插入图片时,就会套用 a 的样式(有背景色)
显然,只需要将fancybox对应的a元素修改回默认值即可
{% fold 点击显/隐代码%}```css
a.fancy-ctn.fancybox {
background-color: transparent ;
border: 0;
}
{% endfold %}
然后,对于上面转换的js,可以发现有比较大的bug
假如我给img指定了width和height
那么,这个转换程序并不会自动转换
因此需要增加对 id class width height 的识别
而假如img不存在某个元素,相应的变量为 undefined
可以使用下面的方法判断一个变量是否为 undefined
typeof(a)=="unfined"
修改后代码如下
{% fold 点击显/隐代码%}```javascript
//是否使用fancybox
if(yiliaConfig.fancybox === true){
require([yiliaConfig.rootUrl + 'fancybox/jquery.fancybox.js'], function(pc){
var isFancy = $(".isFancy");
if(isFancy.length != 0){
var imgArr = $(".article-inner img");
for(var i=0,len=imgArr.length;i<len;i++){
var flag = imgArr.eq(i).attr("no-fancybox");
if(flag=="true")
continue;
var src = imgArr.eq(i).attr("src");
var title = imgArr.eq(i).attr("alt");
var width = imgArr.eq(i).attr("width");
var height = imgArr.eq(i).attr("height");
var id = imgArr.eq(i).attr("id");
var clas = imgArr.eq(i).attr("class");
var temp = "<a";
if(typeof(src)!="undefined")
temp+=" href='"+src+"'";
if(typeof(title)!="undefined")
temp+=" title='"+title+"'";
temp+=" rel='fancy-group' class='fancy-ctn fancybox'><img"
if(typeof(id)!="undefined")
temp+=" id='"+id+"'";
if(typeof(clas)!="undefined")
temp+=" class='"+clas+"'";
if(typeof(src)!="undefined")
temp+=" src='"+src+"'";
if(typeof(alt)!="undefined")
temp+=" alt='"+title+"' title='"+title+"'";
if(typeof(width)!="undefined")
temp+=" width='"+width+"'";
if(typeof(height)!="undefined")
temp+=" height='"+height+"'";
temp+=" /></a>"
imgArr.eq(i).replaceWith(temp);
}
$(".article-inner .fancy-ctn").fancybox();
}
});
}
{% endfold %}
中文博客导航
萌ICP备20213456号