小编gue*_*314的帖子

在javascript中获取矩阵的所有可能选项

我在JavaScript中有一个'item'对象,该项可以有颜色,大小等设置.

我需要在数组中获得所有可能的组合.

所以我们假设我们有一个看起来像这样的项目:

var newItem = {
    name: 'new item',
    Settings: [
        {name: 'color', values: ['green', 'blue', 'red']},
        {name: 'size',  values: ['15', '18', '22']},
        {name: 'gender',values: ['male', 'female']}
    ]
};
Run Code Online (Sandbox Code Playgroud)

我需要以某种方式得到这个:

[
    [{SettingName:'color',value:'green'},{SettingName:'size',value:'15'},{SettingName:'gender',value:'male'}],
    [{SettingName:'color',value:'blue'},{SettingName:'size',value:'15'},{SettingName:'gender',value:'male'}],
    [{SettingName:'color',value:'red'},{SettingName:'size',value:'15'},{SettingName:'gender',value:'male'}],
    [{SettingName:'color',value:'green'},{SettingName:'size',value:'18'},{SettingName:'gender',value:'male'}],
    [{SettingName:'color',value:'blue'},{SettingName:'size',value:'18'},{SettingName:'gender',value:'male'}],
    [{SettingName:'color',value:'red'},{SettingName:'size',value:'18'},{SettingName:'gender',value:'male'}],
    [{SettingName:'color',value:'green'},{SettingName:'size',value:'22'},{SettingName:'gender',value:'male'}],
    [{SettingName:'color',value:'blue'},{SettingName:'size',value:'22'},{SettingName:'gender',value:'male'}],
    [{SettingName:'color',value:'red'},{SettingName:'size',value:'22'},{SettingName:'gender',value:'male'}],
    [{SettingName:'color',value:'green'},{SettingName:'size',value:'15'},{SettingName:'gender',value:'female'}],
    [{SettingName:'color',value:'blue'},{SettingName:'size',value:'15'},{SettingName:'gender',value:'female'}],
    [{SettingName:'color',value:'red'},{SettingName:'size',value:'15'},{SettingName:'gender',value:'female'}],
    [{SettingName:'color',value:'green'},{SettingName:'size',value:'18'},{SettingName:'gender',value:'female'}],
    [{SettingName:'color',value:'blue'},{SettingName:'size',value:'18'},{SettingName:'gender',value:'female'}],
    [{SettingName:'color',value:'red'},{SettingName:'size',value:'18'},{SettingName:'gender',value:'female'}],
    [{SettingName:'color',value:'green'},{SettingName:'size',value:'22'},{SettingName:'gender',value:'female'}],
    [{SettingName:'color',value:'blue'},{SettingName:'size',value:'22'},{SettingName:'gender',value:'female'}],
    [{SettingName:'color',value:'red'},{SettingName:'size',value:'22'},{SettingName:'gender',value:'female'}]
]
Run Code Online (Sandbox Code Playgroud)

javascript arrays json permutation underscore.js

8
推荐指数
1
解决办法
251
查看次数

如何从window.speechSynthesis.speak()调用捕获生成的音频?

以前的问题已经提出了相同或类似的询问

但似乎没有使用创建的变通方法window.speechSynthesis().虽然有一些解决方法使用epeak,meSpeak 如何在Chrome浏览器中创建文本或将文本转换为音频?或向外部服务器发出请求.

如何捕捉和记录的音频输出window.speechSynthesis.speak()调用和返回结果为Blob,ArrayBuffer,AudioBuffer或其他对象类型?

javascript audio html5 text-to-speech webspeech-api

8
推荐指数
1
解决办法
3796
查看次数

如何以编程方式将unix socket命令发送到由浏览器自动生成的系统服务器或将JavaScript转换为Chromium的C++源代码?

目前,ChromiumFirefoxWeb Speech API规范的实现不支持在SSML设置为实例属性并传递给调用时解析语音合成标记语言(SSML); 看看浏览器的SSML解析实现 ; 5.2.3 SpeechSynthesisUtterance属性 ; 如何设置浏览器调用的命令选项?.textSpeechSyntheisUtterancewindow.speechSynthesis.speak()

连接到speech-dispatcher连接的unix套接字的Chromium源代码显示在/src/chrome/browser/speech/tts_linux.cc

  {
    // spd_open has memory leaks which are hard to suppress.
    // http://crbug.com/317360
    ANNOTATE_SCOPED_MEMORY_LEAK;
    conn_ = libspeechd_loader_.spd_open(
        "chrome", "extension_api", NULL, SPD_MODE_THREADED);
  }
Run Code Online (Sandbox Code Playgroud)

似乎反映在 /run/user/1000/speech-dispatcher/log

speechd: Updating client specific settings "linux:chrome:extension_api"
Run Code Online (Sandbox Code Playgroud)

/src/third_party/speech-dispatcher/libspeechd.h中的 Chromium源代码

似乎定义了文档中SSML_DATA_MODE描述的speech-dispatcher内容

speech-dispatcher文档指出用户配置文件可用于设置特定客户端的参数

4.1.6参数设置命令

可以使用以下参数设置命令.对于配置和历史客户端,还有用于为某些其他连接和所有连接设置值的功能.它们在下面单独列出.

C API函数:int spd_set_data_mode(SPDConnection *connection, SPDDataMode mode)设置Speech Dispatcher数据模式.目前,支持纯文本和SSML.如果要在文本中使用索引标记或包含语音参数的更改,SSML特别有用.

mode是请求的数据模式:SPD_DATA_TEXT或 …

javascript c++ linux chromium espeak

7
推荐指数
0
解决办法
373
查看次数

如何检测数据 URL 的 MIME 类型

我正在开发一个 angular 4 应用程序。我有一个 base64 编码的图像。我用 node.js 将它保存在文件系统中。

 if (body.profilepic != "") {
            let base64Data = body.profilepic.split(';base64,').pop();

            fs.writeFile("out.png", base64Data, 'base64', function(err) {
                if (!err) {
                    console.log("saved file")
                }
            });
        }
Run Code Online (Sandbox Code Playgroud)

问题是我无法检测到我正在保存的图像的文件类型。现在它只保存 png。

如何检测我收到的图像字符串的文件类型?

我得到的 base64 编码字符串是这样的:


Run Code Online (Sandbox Code Playgroud)

javascript base64 data-url

7
推荐指数
3
解决办法
1万
查看次数

数组(整数或十进制)到数组,数组到数字(整数或小数)而不使用字符串

需求:

将输入整数或十进制转换为数组,并将可能包含小数的整数数组转换为数字.

限制:

在过程中不要使用字符串方法或将输入或输出转换为字符串(在组成的每个版本的代码中都遵循自我限制).

上下文和用例

BigInt在某些浏览器中可用,但不是 BigDecimal.使用JavaScript编程语言可以实现从整数或十进制到数组和数组到整数或十进制的转换.在过程中,输入和输出不需要转换为字符串.

能够通过调整数组的第n个索引处的十进制或整数来调整整数或十进制的第n位,以尝试直接解决OEIS A217626,例如

~~(128.625*9*1.074)//1243
~~(128.625*9*1.144)//1324
Run Code Online (Sandbox Code Playgroud)

其中可以通过引用数组的索引来操作小数部分,然后将数组转换回数字.

当前规范是WIP,并且可能被认为难以描述与输入的小数部分的处理相关,特别是在存在前导零的情况下.

Input <----------> Output

-123               [-1,-2,-3]
4.4                [4,0.4]
44.44              [4,4,0.4,4]
-0.01              [-0.01]
123                [1,2,3]
200                [2,0,0]
2.718281828459     [2,0.7,1,8,2,8,1,8,2,8,4,5,8,9]
321.7000000001     [3,2,1,0.7,0,0,0,0,0,0,0,0,1]
809.56             [8,0,9,0.5,6]
1.61803398874989   [1,0.6,1,8,0,3,3,9,8,8,7,4,9,8,9]
1.999              [1,0.9,9,9]
100.01             [1,0,0,0.01]
545454.45          [5,4,5,4,5,4,0.4,5]
-7                 [-7]
-83.782            [-8,-3,-0.7,-8,-2]
1.5                [1,0.5]
100.0001           [1,0,0,0.0001]
Run Code Online (Sandbox Code Playgroud)

本质上,我试图将整数或小数传播到数组.将数字或整数转换为数组的函数必须能够转换为生成函数,才能实现

[...Math.E] -> [2, 0.7, 1, 8, 2, 8, 1, 8, 2, 8, 4, 5, 9] -> 2.718281828459
Run Code Online (Sandbox Code Playgroud)

通过将函数设置为Number.prototype[Symbol.iterator]to的值numberToArray …

javascript arrays integer decimal ecmascript-6

7
推荐指数
1
解决办法
531
查看次数

如何使用Array.prototype.filter过滤对象?

特定

var arr = [1,2,true,4,{"abc":123},6,7,{"def":456},9,[10]]
Run Code Online (Sandbox Code Playgroud)

我们可以arr使用Number构造函数过滤数组中的数字项

var res = arr.filter(Number); // [1, 2, true, 4, 6, 7, 9, Array[1]]
Run Code Online (Sandbox Code Playgroud)

true[10]预期在所得数组?如果我们替换falsetruearr

var arr = [1,2,false,4,{"abc":123},6,7,{"def":456},9,[10]] 
var res = arr.filter(Number) // [1, 2, 4, 6, 7, 9, Array[1]]
Run Code Online (Sandbox Code Playgroud)

运用 Array.isArray

var res = arr.filter(Array.isArray) // [Array[1]]
Run Code Online (Sandbox Code Playgroud)

String

var res = arr.filter(String) // [1, 2, true, 4, Object, 6, 7, Object, 9, Array[1]]
Run Code Online (Sandbox Code Playgroud)

如果我们想要在arr对象,索引中过滤项目4,7我们会尝试 …

javascript arrays ecmascript-6 ecmascript-7 ecmascript-next

6
推荐指数
1
解决办法
3846
查看次数

Blob二进制数据存储在哪里?

特定

var data = new Array(1000000);
for (var i = 0; i < data.length; i++) {
  data[i] = 1;
}
var blob = new Blob([data]);
Run Code Online (Sandbox Code Playgroud)

哪个是存储的数组的二进制数据表示?

javascript blob

6
推荐指数
4
解决办法
3880
查看次数

如何对媒体片段的任何部分发出范围请求?

如果我们想要发出一个HTTP/1.0HTTP/1.1请求,例如给定媒体资源的字节 20000 到 100000 或秒 20 到 35 秒,.webm或者.ogg音频或.mp4视频,其中响应将是能够在没有其他部分的情况下播放的离散媒体片段。媒体资源,我们如何实现这一目标?

例如

let headers = new Headers();
let range = 1024 * 1024;
headers.append("Range", "bytes=0-" + range); 
let request = new Request(url, {headers:headers});
fetch(request)
.then(response => response.blob())
.then(data => audio.src = URL.createObjectURL(data));
Run Code Online (Sandbox Code Playgroud)

负载和媒体播放

let headers = new Headers();
let range = 1024 * 1024;
headers.append("Range", "bytes=" + range + "-" + range * 2);
let request = new Request(url, {headers:headers});
fetch(request)
.then(response …
Run Code Online (Sandbox Code Playgroud)

javascript media http codec fetch-api

6
推荐指数
1
解决办法
3284
查看次数

如何在 MediaSource 的 SourceBuffer 中使用“segments”模式在 Chomium、Chorme 和 Firefox 上呈现相同的结果?

如何使用 Blob URL、MediaSource 或其他方法播放媒体片段的串联 Blob?已经能够实现使用记录离散媒体片段的需求MediaRecorder,增加线索所得webm使用文件ts-ebml,并使用记录离散媒体片段作为单个媒体文件MediaSource.modeSourceBuffer一组,以"sequence"在两个铬和Firefox浏览器。

监视器上的 Chromium 问题和可能弃用对“序列”AppendMode 的多轨 SourceBuffer 支持的支持讨论"sequence"模式正在考虑弃用多轨SourceBuffer对象。当被问及如何使用"segments" .mode(默认AppendModeSourceBuffer)实现代码的问题 OP 时,响应本质上是该"segments"模式也支持多轨输入SourceBuffer

但是,当尝试将.modeofSourceBuffer设置为"segments"Chromium 60 的代码仅播放大约一秒钟时,多个附加缓冲区的第一个缓冲区,预期 10 秒播放记录的媒体片段,webm其中在文件中设置了提示的文件被转换ArrayBuffer并传递给.appendBuffer(),而 Firefox当.mode设置为"sequence"和时呈现相同的结果"segments"

在 Chromium 和 Firefox 上呈现预期结果的代码。请注意,如果尝试了,Firefox 不会.mp4 …

javascript firefox google-chrome chromium media-source

6
推荐指数
0
解决办法
1181
查看次数

我在jQuery.readyException中有一条错误消息

我想将jquery更新到最新版本

所以我被3.1.0取代了1.11.0

但它不起作用

我收到一条错误消息“ Lib / js / lib.jquery.js中出现异常,'safari'不是未定义的'

此错误出现在jquery.readyException中

我该如何解决

    jQuery.readyException = function( error ) {
         window.setTimeout( function() {
             throw error; // this point have error.
         } );
    };
Run Code Online (Sandbox Code Playgroud)

javascript jquery jquery-3

5
推荐指数
0
解决办法
1316
查看次数