我想在 JavaScript 中将二进制数据注入到一个对象中。有没有办法做到这一点?
IE
var binObj = new BinaryObject('101010100101011');
那种效果的东西。任何帮助都会很棒。
我想在 JavaScript 中将二进制数据注入到一个对象中。有没有办法做到这一点?
IE
var binObj = new BinaryObject('101010100101011');
那种效果的东西。任何帮助都会很棒。
您可以使用 parseInt:
var bin = parseInt('10101010', 2);
第二个参数(基数)是输入的基数。
这里解释了这个二进制ajax库,还有另一个可以处理更多数据类型的二进制解析器库。
您还可以查看具有二进制 Blob 对象的Google Gears,或者查看为 Flash 制作一个 javascript 包装器,它提供了本机 ByteArray 实现。
或者……你可以坐等,希望所有这些都成为标准:)
在所有最近的浏览器上,您可以执行以下操作:
xhr.overrideMimeType('text/plain; charset=x-user-defined');
并检索一个字符串。要获得二进制结果,您必须执行
data.charCodeAt(pos) & 0xff;
在 Firefox 和 Chrome 的夜间构建中,您可以检索作为ArrayBuffer的值
xhr.responseType = "arraybuffer";
然后可以在那里访问结果
xhr.mozResponseArrayBuffer // Firefox
xhr.response // Chrome
然后你可以在缓冲区上应用一个TypedArray(例如:Int32Array)或一个DataView来读取结果。
为了使这个过程更容易,我制作了一个jQuery Patch来支持二进制类型和一个DataView Wrapper,它使用浏览器的最新可用阅读功能。
JavaScript 对原始二进制数据的支持很少。一般来说,最好生活在这个限制内。但是,我正在考虑为我的一个项目尝试一个技巧,该项目涉及操纵巨大的位图以在 OLAP 数据库中执行设置操作。 这在 IE 中不起作用。
基本思想是这样的:将二进制数据强制转换为 PNG 并将其发送给 JavaScript,例如,位图可能是黑白 PNG,黑色是 100% 透明。然后使用 Canvas 操作进行按位数据操作。
所述HTML5画布包括像素阵列型,从中可以访问字节的图像。Canvas 还支持合成操作,例如 XOR。Lighten 和 Darken 应该可以做 AND 和 OR。这些操作可能会在任何支持它们的浏览器中得到很好的优化——可能使用 GPU。
如果有人尝试过这个,请告诉我它的效果如何。
那将是相反的方式......pow
并且squareroot
可能由 Math-Class 计算......我不知道这是否是最快的方式,但它与“程序员视图”中的 Windows 计算器一样快。
AlertFormatedBin();
function AlertFormatedBin()
{
var vals = decToBinArr(31,8);
var i;
var s = "";
var mod = vals.length % 4;
for(i= 0; i <mod;i++)
{
s+=vals[i];
}
if(i>0)
s+=" ";
var j = i;
for(i;i<vals.length;i++)
{
s+=vals[i];
if(i-j != 0 && (i+1-j)%4 == 0)
{
s+=" ";
}
}
alert(s);
}
function decToBinArr(dec, minSize)
{
var mod = dec%2;
var r = new Array();
if(dec > 1)
{
dec-=mod;
var bd = squareRootRoundedDown(dec);
if(minSize && minSize-1 > bd)
bd = minSize-1;
else
var i;
for(i = bd; i>0;i--)
{
var nxt = pow(2,i);
if(dec >= nxt)
{
r[i] = 1;
dec-=nxt;
}
else
{
r[i] = 0;
}
}
}
r[0]= mod;
r.reverse();
return r;
}
function squareRootRoundedDown(dec)
{
if(dec<2)
return 0;
var x = 2;
var i;
for(i= 1;true;i++)
{
if(x>=dec)
{
i = x == dec ? i : i-1;
break;
}
x= x*2;
}
return i;
}
function pow(b,exp)
{
if(exp == 0)
return 0;
var i = 1;
var r= b;
for(i = 1; i < exp;i++)
r=r*b;
return r;
}