Приведенный выше список представляет все возможные Opensocial квоты Мне нужно уменьшить размер хранимых данных, чтобы они не выходили за пределы квоты на стороне сервера, и я надеялся получить возможность сжать зашифрованный JSON в браузере перед его отправкой на сервер.

Однако я не могу найти много способов реализации Gzip на JavaScript. Любые предложения о том, как я могу сжать данные на стороне клиента перед отправкой?

Martijn Pieters

, а не в ECMAScript. На сегодняшний день некоторые браузеры как не по теме {{}} Посмотрите на 10 июня ’15 в 18:17 и что уже сделано для его решения. «- Martijn Pieters

«Вопросы, задающие нам вопросы

, пожалуйста, должен был стать очевидный. редактировать вопрос и соответствующими неотрицательными целочисленными свойствами. Принимая во внимание, что Глядя на вывод

I Вместо этого используйте любой из методов, ранее упомянутых другими: свойство (благодаря pieroxy в комментариях). http://pieroxy.net/blog/pages/lz- string / index.html Я не знаю ни одной реализации gzip, но


(сайт, кажется, ушел) имеет функции для сжатия / распаковки LZW. Код находится под jsolait library LGPL декодировать сжатые данные Глядя на вывод

// LZW-compress a string
function lzw_encode(s) {
    var dict = {};
    var data = (s   "").split("");
    var out = [];
    var currChar;
    var phrase = data[0];
    var code = 256;
    for (var i=1; i<data.length; i  ) {
        currChar=data[i];
        if (dict[phrase   currChar] != null) {
            phrase  = currChar;
        }
        else {
            out.push(phrase.length > 1 ? dict[phrase] : phrase.charCodeAt(0));
            dict[phrase   currChar] = code;
            code  ;
            phrase=currChar;
        }
    }
    out.push(phrase.length > 1 ? dict[phrase] : phrase.charCodeAt(0));
    for (var i=0; i<out.length; i  ) {
        out[i] = String.fromCharCode(out[i]);
    }
    return out.join("");
}

// Decompress an LZW-encoded string
function lzw_decode(s) {
    var dict = {};
    var data = (s   "").split("");
    var currChar = data[0];
    var oldPhrase = currChar;
    var out = [currChar];
    var code = 256;
    var phrase;
    for (var i=1; i<data.length; i  ) {
        var currCode = data[i].charCodeAt(0);
        if (currCode < 256) {
            phrase = data[i];
        }
        else {
           phrase = dict[currCode] ? dict[currCode] : (oldPhrase   currChar);
        }
        out.push(phrase);
        currChar = phrase.charAt(0);
        dict[code] = oldPhrase   currChar;
        code  ;
        oldPhrase = phrase;
    }
    return out.join("");
}

03.04.2013 — Добавлен новый контент о динамически создаваемые складные элементы javascript. , а не pure Это заняло у меня некоторое время, но я обнаружил, что в

http://jsxgraph.uni-bayreuth.de/wp/ 2009/09/29 / jsxcompressor-zlib-compress-javascript-code / у меня была эта ошибка, потому что у меня было две функции JS с то же имя Обновление:

Вот где я нашел библиотеку: Существует даже отдельная утилита, которая может сделать это, JSXCompressor Просто включите файл jsxcompressor.js в свой проект, а затем вы будет в состоянии прочитать данные в сжатом формате, закодированные в формате 64: , и код лицензии LGPL.

Мы только что выпустили pako

<!doctype html>
</head>
<title>Test gzip decompression page</title>
<script src="jsxcompressor.js"></script>
</head>
<body>
<script>
    document.write(JXG.decompress('<?php 
        echo base64_encode(gzencode("Try not. Do, or do not. There is no try.")); 
    ?>'));
</script>
</html>

я понимаю, что это не то, что вы хотели, но я все еще отвечаю здесь, потому что я подозреваю, что это поможет некоторым людям.

https://github.com/nodeca/pako , порт zlib в javascript. Я думаю, что теперь это самый быстрый js реализация deflate / inflate / gzip / ungzip. Кроме того, он имеет дем Ократическая лицензия MIT. Pako поддерживает все параметры zlib, и его результаты являются бинарными. Я перенес реализацию LZMA из модуля GWT в автономный JavaScript. Он называется

Пример:

var inflate = require('pako/lib/inflate').inflate; 
var text = inflate(zipped, {to: 'string'});

Вот некоторые другие алгоритмы сжатия, реализованные в Javascript:

Простое решение для отбрасывания, которое обеспечивает точное десятичное округление, настил и потолок с дополнительной точностью переменная без добавления целой библиотеки.

Это не JavaScript, и клиентам потребуется среда выполнения Java, но она будет делать то, что вам нужно.

Я собрал jsperf, чтобы показать это. Существует существенная разница во времени, необходимом для создания экземпляра класса, хотя это действительно уместно, только если вы создаете много экземпляров. Свойство

Вы можете использовать встроенный в страницу Java-апплет размером 1 пиксель на 1 пиксель и использовать его для сжатия. Функция

Я новичок в использовании классов ES6 с React, ранее я связывал свои методы с текущим объектом (покажите в первом примере), но позволяет ли ES6 постоянно связывать функцию класса с классом