通过前面几章的介绍,我们可以看到,WordPress自定义字段的功能是非常强大的,在我们开发WordPress主题时,合理的应用wordpress自定义字段,以我们创作的wordpress主题功能提升是非常用帮助的。本章我们再来介绍如何在wordpress自定义面版中添加图片上传功能。
其实在wordpress文章发表页,wordpress就自带有图片上传按钮——“添加媒体”,所以,在文章发表页基本上不需要再添加这个wordpress自定义面版的图片上传模块。但是在我们制作wordpress主题自定义PAGE页面时,就可能会用到这个。下面,就一起来看看怎样添加wordpress自定义面版图片上传功能吧。
1、接上一章,在metabox.php文件中的二维数组中添加“图片上传”这一项,代码如下:
"uploads" => array( "name" => "_meta_uploader", "std" => '', "title" => "图片上传", "type"=>"uploader"),
2、然后在metabox.php文件中的switch判断语句中添加图片上传显示代码,代码如下:
//图片上传 case 'uploader': echo'<h4>'.$meta_box['title'].'</h4>'; if($meta_box['std'] != ''){ echo '<span id="'.$meta_box['name'].'_value_img"><img src='.$meta_box['std'].' alt="" /></span>';} echo '<input class="ashu_upload_input" type="text" size="40" value="'.$meta_box['std'].'" name="'.$meta_box['name'].'_value"/>'; echo '<input type="button" value="上传" class="ashu_bottom"/>'; echo '<br/>'; break;
3、通过js代码来实现图片上传功能。上面这些代码,只能调到上传图片上传的对话框,但是,点击上传按钮时是没有任何反应的,也就是说还不能实现图片上传,更不能实现实时预览。所以我们需要添加一个js文件,来实现这种功能。在主题文件夹下创建一个js文件夹,然后再在js文件夹里创建一个名为metabox_up.js的js文件,通过dreamweaver打开这个metabox_up.js,在里添加如下代码:
jQuery(document).ready(function() { jQuery('input.ashu_bottom').click(function() { custom_editor = true; targetfield = jQuery(this).prev('input'); tb_show('', 'media-upload.php?type=image&TB_iframe=true'); window.original_send_to_editor = window.send_to_editor; window.send_to_editor = function(html) { if (custom_editor) { imgurl = jQuery('img',html).attr('src'); jQuery(targetfield).val(imgurl).focus(); custom_editor = false; tb_remove(); }else{ window.original_send_to_editor(html); } } return false; }); //图片实时预览ashu_upload_input为图片url文本框的class属性 jQuery('input.ashu_upload_input').each(function() { jQuery(this).bind('change focus blur', function() { //获取改文本框的name属性后面 $select = '#' + jQuery(this).attr('name') + '_img'; $value = jQuery(this).val(); $image = '<img src ="'+$value+'" />'; var $image = jQuery($select).html('').append($image).find('img'); //set timeout because of safari window.setTimeout(function() { if(parseInt($image.attr('width')) < 20) { jQuery($select).html(''); } },500); }); }); });
4、调用这个metabox_up.js文件。在metabox.php文件中添加如下代码来调用js文件:
wp_enqueue_script('metabox_up', get_template_directory_uri(). '/js/metabox_up.js');
到这里,给wordpress自定义面版添加图片上传功能就结束了。我们来浏览一下效果,如下图:
黄飞鸿热灸馆加盟项目,整店输出模式,专业热灸加盟技术培训,一个专业做中医养生的连锁品牌。源自黄飞鸿的嫡孙继承了黄飞鸿先生的遗志,多年来一直坚定不移地致力于大健康产业,并创立了黄飞鸿热灸馆;主要业务服务有黄飞鸿热炙理疗,黄飞鸿热炙理疗馆加盟,黄飞鸿理疗馆,黄飞鸿热灸,黄飞鸿养生馆加盟,黄飞鸿养生馆加盟,黄飞鸿热灸馆,黄飞鸿热灸体验馆,黄飞鸿热灸馆加盟,黄飞鸿热灸理疗馆,黄飞鸿热灸膏
TokenPocket钱包支持数字资产存储。每天走势掌握,功能强大,在线管理数字货币,超多币种推送,多种交易方式,私钥用户自持且轻便易用的以太坊轻钱包。tp支持多资产类型,如:TokenPocket、ETH、QTUM、AE、BTM等大多数主流币种,让tp钱包更好地融入你的生活。
浙江丰安齿轮股份有限公司成立于1999年1月,是一家集开发、设计、制造、销售服务为一体的齿轮专业制造商,占地面积93亩,总资产3亿余元,主要设备400余台。公司于2017年1月在“新三板”挂牌,股票代码870508。公司以精湛的技术、过硬的品质、优良的服务来赢得客户满意,努力打造业界一流齿轮制造企业。
我公司系高新技术企业,专业从事空气净化的产品生产、工程服务及洁净技术的应用与研究,提供从空调处理设备、空调自动控制系统到洁净室系统全面服务,为各类工业用空气处理提供一揽子解决方案及交钥匙工程。 产品遍及全国几十个省市,并出口至巴基斯坦、伊朗等国家。我公司在化纤工艺空调领域精耕细作20余年,2001年进入医药、电子等行业的净化空调设备。 本公司拥有雄厚的技术力量和良好的售后服务,承接系统设计、技术咨询、产品制造、技术改造等项目。设备采用工业计算机、可编程序(PLC)控制器、数字直接控制器(DDC)等智能控制器,可实现节能显著的运行系统(节能策略有:新回风的焓值控制、二次回风、送风机的变频调速;非露点控制方案在过渡季节节能50%。在化纤纺丝行业采用的节能措施,同样可在医药行业的净化空调上使用);采用与国际惯例接轨的CAD设计和质量保证体系。
双友科技为客户提供直缝埋弧焊管生产线、直缝高频焊管生产线、螺旋埋弧焊管生产线、钢管内外防腐生产线,石油套管生产线,热处理生产线以及其他系列产品。同时公司致力于为高端铝业服务,为客户提供更为高效,节能,环保,安全的铸铝生产线及其相关设备。公司积极推进国际化发展战略,逐步实现品牌、市场、团队、技术、管理与国际化标准接轨。此外,公司与众多国际知名管材和铝材生产商建立了紧密的合作关系,在中东设立了海外分支机构。双友科技旨在将中国的高端制造带给世界。
南京三超新材料股份有限公司成立于1999年1月,注册资本9360万元,2017年4月21日,在深圳创业板成功挂牌上市。占地面积130亩,建筑面积约86,000平方米。是一家专业从事金刚石、立方氮化硼工具的研发、生产与销售的高新技术企业,现拥有金刚石砂轮和金刚石线两大类相互协同的产品系列,应用于硅、蓝宝石、石英、铁氧体、钕铁硼、陶瓷、玻璃、硬质合金等硬脆材料的精密切割、磨削与抛光。 公司自成立以来,始终坚持"以人为本、技术优先"的发展理念,先后引入多名外籍专家,并在日本成立了超硬材料工具的专业研发机构。经过多年研发,公司成为国内最早通过自主研发掌握金刚线制造的相关技术,成功实现产业化的企业之一,并且打破了国外企业的技术垄断,与新研发成功的硅片背面减薄砂轮、硅片倒角砂轮、PAD修整器等产品,为半导体及太阳能光伏行业提供了优质的金刚石工具,并凭借良好的品质与高性价比,赢得了众多实力用户认可,在国内形成了较高的行业影响力。