是否可以使用例如ucfirst使{CITY}输出大写?可以通过某种方式更改此代码以使其大写吗?
<?php
$city_meta = get_option('city_meta' );
$city_description = get_option('city_description' );
$default_api = get_option('default_api' );
/* Update Settings */
if(isset($_POST['submit_changes'])){
update_option('city_meta',$_POST['city_meta']);
update_option('city_description',$_POST['city_description']);
$info =weatherCity::getCities();
//$info =array_slice($info, 0, 3);
$sr=0;
foreach($info as $key=>$value):
$postTitle = 'Väder '.$value->name;
global $wpdb;
$pageInfo=$wpdb->get_row("SELECT ID FROM `".$wpdb->prefix."posts` WHERE post_title = '" . $postTitle . "' AND `post_type`='page' ");
if(!empty($pageInfo)):
$metaTitle=$_POST['city_meta'];
$metaDesc=$_POST['city_description'];
$metaTitle=str_replace('{CITY}',$value->name,$metaTitle);
$metaDesc=str_replace('{CITY}',$value->name,$metaDesc);
update_post_meta($pageInfo->ID,'_yoast_wpseo_title',$metaTitle);
update_post_meta($pageInfo->ID,'_yoast_wpseo_metadesc',$metaDesc);
$sr++;
endif;
endforeach;
set_error_message( _e('City Meta Settings has been updated succesfully','weather'),'0');
foreceRedirect(admin_url('admin.php?page=city_meta') );
exit;
}
?>
如果有人能找到一个简单的解决方案,那就太好了。 : - )
答案 0 :(得分:1)
您可以使用ucwords()
$metaTitle=ucwords(str_replace('{CITY}',$value->name,$metaTitle));
$metaDesc=ucwords(str_replace('{CITY}',$value->name,$metaDesc));
这将大写字符串中每个单词的第一个字符。
PHP.Net链接
答案 1 :(得分:1)
谢谢,@ dotkomm和@Harvey Fletcher这是你的答案的组合,解决了这个问题。
解决方案如下所示:
$metaTitle=str_replace('{CITY}', ucwords($value->name),$metaTitle);
$metaDesc=str_replace('{CITY}', ucwords($value->name),$metaDesc);
答案 2 :(得分:0)
有几种方法,我认为最优雅的方法是使用css text-transform属性大写text-transform: capitalize;
,因为它不会改变数据
但是ucfirst()
也应该做这个工作,但是这里的数据会被改变以便进一步处理
你也可以在mysql查询中完成这项工作
在您的示例中,如果您要使用ucfirst()
,则应替换
$metaTitle=str_replace('{CITY}',$value->name,$metaTitle);
$metaDesc=str_replace('{CITY}',$value->name,$metaDesc);
与
$metaTitle=str_replace('{CITY}', ucfirst($value->name),$metaTitle);
$metaDesc=str_replace('{CITY}', ucfirst($value->name),$metaDesc);