我在曲线形状的文字中添加了(小帽,全帽,无帽和普通)等字体样式,但在这种风格中只有小型帽子,所有帽子和没有帽子都在工作,但正常情况下它不起作用。为什么?
正常文本应该看起来像'正常'意味着第一个字母应该是大写字母,剩下的应该是小的。请尽快给我答案。 有没有人回答我的问题。
<html xmlns="http://www.w3.org/1999/xhtml">
<body>
<form>
Top Center:<input type="text" name="Location 3" id="ta3" class="changeMe2" maxlength="15"><br /><br />
Bottom Center:<input type="text" name="Location 4" id="ta4" class="changeMe2" maxlength="25">
<font color="#000000">Font Style :</font>
<select id="size" >
<option value="0">[No Engraving]</option>
<option value="variant">Small Caps</option>
<option value="uppercase">All Caps</option>
<option value=" lowercase">No Caps</option>
<option value="capitalize">Normal</option>
</select>
</form>
<div id="container3" class="changeMe2" style="left:112px; font-size:18px; text-align:center;letter-spacing:-1px;
position: absolute;
top:117px;
z-index: 999;">
<div id="float3">
<p>
</p>
</div>
</div>
<div id="container4" class="changeMe2" style="left:109px; font-size:18px; text-align:center;letter-spacing:-1px;
position: absolute;
top: 217px;
z-index: 999;">
<div id="float4">
<p>
</p>
</div>
</div>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
<title>Untitled Document</title>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>
<script type="text/javascript" src="arctext.js"></script>
<script type="text/javascript">
$(window).load(function(){
function curveTop(){
var text = '<p>' + $('#ta3').val() + '</p>',
size = $('#size').val();
$('#float3')
.css({
fontStyle: size
})
.html(text)
.find('p')
.arctext({radius:80});
}
$('#ta3').keyup( curveTop );
$("#size").change( curveTop );
function curveBottom(){
var text = '<p>' + $('#ta4').val() + '</p>',
size = $('#size').val();
$('#float4')
.css({
fontStyle: size
})
.html(text)
.find('p')
.arctext({radius: 80, dir: +2});
}
$('#ta4').keyup( curveBottom );
$("#size").change( curveBottom );
});
$('#ta3').keyup(function(){
$('#float3').html("<p align = 'center'>"+$(this).val()+"</p>");
});
$("#size").change(function() {
if($("#size option:selected").val()=="variant") {
$('#float3').css("font-variant", "small-caps");
}
else{
$('#float3').css("font-variant", "normal");
$('#float3').css("text-transform", $(this).val());
}
});
$('#ta4').keyup(function(){
$('#float4').html("<p align = 'center'>"+$(this).val()+"</p>");
});
$("#size").change(function() {
if($("#size option:selected").val()=="variant") {
$('#float4').css("font-variant", "small-caps");
}
else{
$('#float4').css("font-variant", "normal");
$('#float4').css("text-transform", $(this).val());
}
});
</script>
</head>
</body>
</html>
请参阅此代码,请执行此操作。
答案 0 :(得分:0)
我把你的例子放在jsFiddle上:
http://jsfiddle.net/h5c6Y/2/
正如您在Firefox和Chrome中所期望的那样,文本大写。除非在应用文本转换后更新文本,否则它在IE 8中不起作用。所以我修改了你的代码,以便在应用转换后更新文本。
$("#size").change(function() {
if($("#size option:selected").val()=="variant") {
$('#float3,#float4').css("font-variant", "small-caps");
} else {
$('#float3,#float4').css("font-variant", "normal");
$('#float3,#float4').css("text-transform", $(this).val());
}
// Added the next two lines to force IE to refresh the text
$('#float3').html("<p align = 'center'>"+$(this).val()+"</p>");
$('#float4').html("<p align = 'center'>"+$(this).val()+"</p>");
});