主要目标:在输入框中,数字应以文字转换。 现在,它只显示文本框中的数字,而不是转换 HTML:
<div ng-app="app" ng-controller="myCtrl">
<span ng-init="W_cst='<?php echo $Cex; ?>'">{{W_cst | words}}</span>
</div>
PHP:
<?php
$cex=125;
?>
Angular JS:
<script>
var app = angular.module('app',[]);
app.controller('myCtrl',function($scope){
$scope.cst=function(){
var t;
t=100;
return t*0.125;
}
});
app.filter('words', function() {
function isInteger(x) {
return x % 1 === 0;
}
return function(value) {
if (value && isInteger(value))
return toWords(value);
return value;
};
});
var th = ['','thousand','million', 'billion','trillion'];
var dg = ['zero','one','two','three','four', 'five','six','seven','eight','nine'];
var tn = ['ten','eleven','twelve','thirteen', 'fourteen','fifteen','sixteen', 'seventeen','eighteen','nineteen'];
var tw = ['twenty','thirty','forty','fifty', 'sixty','seventy','eighty','ninety'];
function toWords(s)
{
s = s.toString();
s = s.replace(/[\, ]/g,'');
if (s != parseFloat(s)) return 'not a number';
var x = s.indexOf('.');
if (x == -1) x = s.length;
if (x > 15) return 'too big';
var n = s.split('');
var str = '';
var sk = 0;
for (var i=0; i < x; i++)
{
if ((x-i)%3==2)
{
if (n[i] == '1')
{
str += tn[Number(n[i+1])] + ' ';
i++;
sk=1;
}
else if (n[i]!=0)
{
str += tw[n[i]-2] + ' ';
sk=1;
}
}
else if (n[i]!=0)
{
str += dg[n[i]] +' ';
if ((x-i)%3==0) str += 'hundred ';
sk=1;
}
if ((x-i)%3==1)
{
if (sk) str += th[(x-i-1)/3] + ' ';
sk=0;
}
}
if (x != s.length)
{
var y = s.length;
str += 'point ';
for (var i=x+1; i<y; i++) str += dg[n[i]] +' ';
}
return str.replace(/\s+/g,' ');
}
window.toWords = toWords;
</script>
请告诉我我哪里出错了。提前谢谢。
答案 0 :(得分:0)
这不是ng-value
的正确使用,该指令应该用于<option>
或input[radio]
元素。请在此处查看ng-value
文档:https://docs.angularjs.org/api/ng/directive/ngValue
您需要使用ng-model
将输入的值存储到某处的文本字段中。然后,您可以使用函数读取该值,将其转换为单词并返回字符串。
我在这里创建了一个快速示例:https://jsfiddle.net/aza2xprp/