{"id":3951,"date":"2022-12-29T18:21:23","date_gmt":"2022-12-29T18:21:23","guid":{"rendered":"http:\/\/kevinbk.com\/?p=3951"},"modified":"2022-12-29T18:37:30","modified_gmt":"2022-12-29T18:37:30","slug":"customizando-codigo-do-responsivevoice","status":"publish","type":"post","link":"https:\/\/kevinbk.com\/zh\/customizando-codigo-do-responsivevoice\/","title":{"rendered":"\u81ea\u5b9a\u4e49ResponsiveVoice\u7684\u4ee3\u7801"},"content":{"rendered":"

ResponsiveVoice\u662f\u4e00\u4e2a\u8457\u540d\u7684\u548c\u514d\u8d39\u7684\u8bed\u6587\u53d1\u97f3API\u5de5\u5177,\u5141\u8bb8\u7528\u6237\u5728\u60a8\u7684\u7f51\u7ad9\u4e0a\u6dfb\u52a0\u6587\u672c\u9605\u8bfb,\u5355\u8bcd\u548c\u6bb5\u843d,\u4f46\u5982\u4f55\u5b9a\u5236\u8fd9\u4e9b\u4ee3\u7801\u4ee5\u5b9e\u73b0\u60a8\u60f3\u8981\u7684\u65b9\u5f0f? <\/p>\n\n\n\n

ResponsiveVoice\u867d\u7136\u662f\u514d\u8d39\u7684,\u4f46\u5b83\u6709\u4e00\u4e2a\u4ed8\u8d39\u7684\u8ba1\u5212,\u63d0\u4f9b\u652f\u6301\u3002\u6700\u5927\u7684\u95ee\u9898\u662f\u514d\u8d39\u7528\u6237\u6ca1\u6709\u5f97\u5230\u6ce8\u610f\u3002 <\/p>\n\n\n\n

\u5f53\u6211\u8bd5\u56fe\u4f7f\u7528\u548c\u7f16\u8f91\u5404\u79cd\u4ee3\u7801\u65f6,\u6211\u65e0\u6cd5\u8ba9\u5b83\u4ee5\u6211\u60f3\u8981\u7684\u65b9\u5f0f\u5de5\u4f5c\u3002\u5e78\u8fd0\u7684\u662f,\u7ecf\u8fc7\u4eba\u5de5\u667a\u80fd\u7684\u5e2e\u52a9,\u7ecf\u8fc7\u51e0\u4e2a\u5c0f\u65f6\u540e,\u6211\u53ef\u4ee5\u7528JavaScript\u7f16\u8f91\u5b83\u4ee5\u6211\u60f3\u8981\u7684\u65b9\u5f0f\u3002 <\/p>\n\n\n\n

\u5982\u4f55\u5728\u60a8\u7684\u7f51\u7ad9\u4e0a\u6dfb\u52a0 ResponsiveVoice<\/h2>\n\n\n\n

\u8981\u5728\u60a8\u7684\u7f51\u7ad9\u4e0a\u6dfb\u52a0ResponsiveVoice,\u60a8\u9700\u8981\u521b\u5efa\u4e00\u4e2a\u5e10\u6237\u5e76\u4e3a\u60a8\u7684\u7f51\u7ad9\u751f\u6210API\u5bc6\u94a5,\u7136\u540e\u53ea\u9700\u5c06\u4ee5\u4e0b\u811a\u672c\u653e\u5165\u60a8\u7684\u9879\u76ee\u6807\u9898\u3002 <\/p>\n\n\n\n

<script src=\"https:\/\/code.responsivevoice.org\/responsivevoice.js?key=YOUR_UNIQUE_KEY\"><\/script><\/code><\/pre>\n\n\n\n

\u6dfb\u52a0\u6b64\u811a\u672c\u540e,\u60a8\u53ef\u4ee5\u521b\u5efa\u5176\u4ed6 javascript,\u4ee5\u4fbf\u5728\u60a8\u7684\u7f51\u7ad9\u4e0a\u8fd0\u884c\u3002\u60a8\u53ef\u4ee5\u8c03\u7528API\u6765\u53d1\u97f3\u60a8\u6240\u9009\u62e9\u7684\u6587\u672c,\u4f7f\u7528\u5b57\u7b26\u4e32\u3001\u53d8\u91cf\u6216\u9884\u5b9a\u4e49\u6587\u672c\u3002 <\/p>\n\n\n\n

\u60a8\u53ef\u4ee5\u8ba9 Script \u53d1\u97f3\u7279\u5b9a\u6807\u7b7e\u3001\u9009\u62e9\u7684\u6587\u672c\u6216\u6574\u4e2a\u9875\u9762,\u60a8\u53ea\u9700\u8981\u521b\u5efa javascript \u5e76\u4f7f\u7528\u4ee5\u4e0b\u4ee3\u7801\u8c03\u7528 responsivevoice: <\/p>\n\n\n\n

responsiveVoice.speak(\"text-or-var\");<\/code><\/pre>\n\n\n\n

\u5728 responsiveVoice.Speak \u4e2d\u6dfb\u52a0\u53c2\u6570<\/h2>\n\n\n\n

\u8981\u5b9a\u5236 ResponsiveVoice \u4ee3\u7801,\u60a8\u53ef\u4ee5\u4f7f\u7528\u5728 ResponsiveVoice \u6587\u6863\u4e2d\u63d0\u4f9b\u7684\u8bbe\u7f6e\u9009\u9879\u3002 \u4e00\u4e9b\u6700\u5e38\u89c1\u7684\u9009\u9879\u5305\u62ec:<\/p>\n\n\n\n

    \n
  1. \u58f0\u97f3 (sh\u0113ngy\u012bn)<\/code>: \u5141\u8bb8\u60a8\u6307\u5b9a\u5c06\u7528\u4e8e\u64ad\u653e\u6587\u672c(\u8bed\u8a00)\u7684\u58f0\u97f3\u3002\u60a8\u53ef\u4ee5\u4ece\u53ef\u7528\u7684\u58f0\u97f3\u4e2d\u9009\u62e9\u6240\u9009\u62e9\u7684\u8bed\u8a00\u3002<\/li>\n\n\n\n
  2. \u8d39\u7387<\/code>: \u5141\u8bb8\u63a7\u5236\u8bed\u97f3\u901f\u5ea6.\u8f83\u9ad8\u7684\u503c\u4f1a\u5bfc\u81f4\u66f4\u5feb\u7684\u8bed\u97f3,\u800c\u8f83\u4f4e\u7684\u503c\u4f1a\u5bfc\u81f4\u66f4\u6162\u7684\u8bed\u97f3\u3002<\/li>\n\n\n\n
  3. \u6295\u7403<\/code>: \u5141\u8bb8\u63a7\u5236\u8bed\u97f3\u7684\u8bed\u97f3\u3002\u8f83\u9ad8\u7684\u503c\u4f1a\u5bfc\u81f4\u66f4\u5c16\u9510\u7684\u8bed\u97f3,\u800c\u8f83\u4f4e\u7684\u503c\u4f1a\u5bfc\u81f4\u66f4\u4e25\u91cd\u7684\u8bed\u97f3\u3002<\/li>\n\n\n\n
  4. \u97f3\u91cf<\/code>: \u5141\u8bb8\u63a7\u5236\u8bed\u97f3\u91cf.\u8f83\u9ad8\u7684\u503c\u4f1a\u5bfc\u81f4\u66f4\u9ad8\u7684\u8bed\u97f3,\u800c\u8f83\u4f4e\u7684\u503c\u4f1a\u5bfc\u81f4\u66f4\u4f4e\u7684\u8bed\u97f3\u3002<\/li>\n<\/ol>\n\n\n\n

    \u8981\u4f7f\u7528\u8fd9\u4e9b\u9009\u9879,\u53ea\u9700\u5728\u547c\u53eb\u51fd\u6570\u65f6\u5c06\u5b83\u4eec\u6dfb\u52a0\u4e3a\u53c2\u6570\u3002 responsiveVoice.speak()<\/code>.<\/p>\n\n\n

    \n
    \"-\"<\/figure><\/div>\n\n\n

    \u6dfb\u52a0\u6309\u94ae\u6765\u53d1\u97f3 HTML \u5143\u7d20<\/h2>\n\n\n\n

    \u5982\u679c\u4f60\u60f3\u53d1\u97f3\u4e00\u4e2a\u6807\u7b7e\u7684\u5185\u5bb9,\u4f60\u53ef\u4ee5\u4f7f\u7528\u4e0b\u9762\u7684 javascript\u3002\u5728\u8fd9\u79cd\u60c5\u51b5\u4e0b,Script\u4f1a\u6dfb\u52a0\u4e00\u4e2a\u6309\u94ae,\u5728\u6bcf\u4e2a\u7f51\u7ad9\u4e0a,\u5220\u9664\u4e00\u4e9bHTML\u6807\u7b7e(\u5728\u6211\u7684\u4f8b\u5b50\u4e2d, <rt>\u548c\u5176\u4ed6),\u5e76\u53d1\u97f3\u6807\u7b7e\u7684\u5185\u5bb9\u3002 <\/p>\n\n\n\n

    function adicionarBotoesPlay() {\n  \/\/ Obt\u00e9m todas as tags <pre> da p\u00e1gina\n  var tagsPre = document.getElementsByTagName(\"pre\");\n  \/\/ Para cada tag <pre>...\n  for (var i = 0; i < tagsPre.length; i++) {\n    \/\/ Cria um novo bot\u00e3o de play\n    var botaoPlay = document.createElement(\"button\");\n\t\tbotaoPlay.setAttribute(\"class\", \"playbt\");\n    botaoPlay.innerHTML = \"\u25b7\";\n    \/\/ Adiciona o bot\u00e3o de play \u00e0 tag <pre>\n    tagsPre[i].appendChild(botaoPlay);\n    \/\/ Configura o evento de clique do bot\u00e3o para chamar a fun\u00e7\u00e3o de pron\u00fancia do ResponsiveVoice\n    botaoPlay.addEventListener(\"click\", function() { \n      \/\/ Obt\u00e9m o conte\u00fado da tag <pre>\n      \/\/ Obt\u00e9m o elemento HTML que voc\u00ea deseja selecionar\n      var conteudoPre = this.parentNode.innerHTML;\n      \/\/ Substitui todas as tags <rt> e seu conte\u00fado pelo texto vazio\n      var textoSemRt = conteudoPre.replace(\/<rt>([\\s\\S]*?)<\\\/rt>\/g, \"\").replace(\/<button[^>]*>.*?<\\\/button>\/g, \"\");\n\t\t\tvar textoSemHtml = textoSemRt.replace(\/<[^>]*>\/g, \"\");\n      \/\/ Solicita a pron\u00fancia do conte\u00fado sem as tags <rt> pelo ResponsiveVoice Text To Speech\n\t\t\t\/\/ Cria um novo elemento de texto com o texto selecionado\n\t\t\tresponsiveVoice.speak(\" \");\n \u00a0 \u00a0 \u00a0responsiveVoice.speak(textoSemHtml, \"Japanese Female\", {\n\t\t  rate: 0.8,\n  \t\tonend: function() {\n    \/\/ Executa alguma a\u00e7\u00e3o depois que a pron\u00fancia \u00e9 conclu\u00edda\n  }\n});\n    });\n  }\n}\n\/\/ Executa a fun\u00e7\u00e3o quando a p\u00e1gina terminar de carregar\nwindow.addEventListener(\"load\", adicionarBotoesPlay);<\/code><\/pre>\n\n\n\n

    \u4e0a\u9762\u7684\u4ee3\u7801\u4ece\u6dfb\u52a0\u6309\u94ae\u5f00\u59cb,\u7136\u540e\u53d6 <pre> \u6807\u7b7e,\u7136\u540e\u8bbe\u7f6e\u4e00\u4e2a\u4e8b\u4ef6,\u5982\u679c\u6309\u94ae\u53d1\u751f,\u5b83\u5c06\u83b7\u5f97\u6807\u7b7e\u7684\u5185\u5bb9 <pre> \u4ee5\u53ca HTML,\u5b83\u5c06\u4f7f\u7528\u201c\u66ff\u6362\u201d\u6807\u7b7e <rt> \u548c\u5176\u4ed6\u6807\u7b7e,\u5305\u62ec\u6309\u94ae\u672c\u8eab\u7684\u5185\u5bb9\u3002 <\/p>\n\n\n\n

    \u7136\u540e,\u4f7f\u7528\u6e05\u6d01\u6587\u672c\u53d8\u91cf,\u5b83\u4ee50.8\u7684\u901f\u5ea6\u5728\u65e5\u8bed\u8fdb\u884c\u53d1\u97f3\u3002 <\/p>\n\n\n\n

    \u8fd9\u7bc7\u6587\u7ae0\u4e2d\u7684\u4ee3\u7801\u53ef\u4ee5\u6dfb\u52a0\u5230\u60a8\u7f51\u7ad9\u7684\u6216\u6807\u7b7e\u5185\u7684\u4e2d\u3002 <\/pre>\n\n\n\n

    \u9605\u8bfb\u5c4f\u5e55\u4e2d\u9009\u62e9\u7684\u5185\u5bb9<\/h2>\n\n\n\n

    \u539f\u6765,ResponsiveVoice\u6709\u4e00\u4e2a\u9009\u9879,\u5141\u8bb8\u9605\u8bfb\u9875\u9762\u6240\u9009\u62e9\u7684\u5185\u5bb9. \u60a8\u53ef\u4ee5\u4f7f\u7528\u81ea\u5df1\u7684JavaScript\u5e76\u5b9a\u5236\u5b83\u3002 \u5728\u6211\u7684\u60c5\u51b5\u4e0b,\u6211\u53ea\u53d1\u97f3\u4e86\u65e5\u8bed\u5b57\u6bcd\u3002 <\/p>\n\n\n\n

    responsiveVoice.setDefaultVoice(\"Japanese Female\");\ndocument.addEventListener(\"mouseup\", function() {\n  \/\/ Obt\u00e9m o texto selecionado pelo usu\u00e1rio\n  var selecao = window.getSelection().toString();\n  \/\/ Verifica se o texto selecionado n\u00e3o est\u00e1 vazio\n  if (selecao) {\n    \/\/ Verifica se o texto selecionado s\u00f3 cont\u00e9m caracteres japoneses\n    var caracteresJaponeses = \/^[\\u3041-\\u3096\\u30A0-\\u30FF\\u4E00-\\u9FFF]+$\/;\n    if (caracteresJaponeses.test(selecao)) {\n      \/\/ Solicita a pron\u00fancia do texto selecionado pelo ResponsiveVoice Text To Speech\n      responsiveVoice.speak(selecao, \"Japanese Female\", {\n        onend: function() {\n          \/\/ Executa alguma a\u00e7\u00e3o depois que a pron\u00fancia \u00e9 conclu\u00edda\n}\n      });\n    }\n  }\n});<\/code><\/pre>\n\n\n\n

    \u5e0c\u671b\u8fd9\u4e9b\u4ee3\u7801\u80fd\u5e2e\u52a9\u60a8\u89e3\u51b3\u60a8\u4e0e ResponsiveVoice \u76f8\u5173\u7684\u95ee\u9898,\u5982\u679c\u60a8\u9700\u8981\u8fdb\u4e00\u6b65\u5b9a\u5236\u4ee3\u7801,\u53ea\u9700\u5411\u4eba\u5de5\u667a\u80fd\u63d0\u4f9b\u5e2e\u52a9\u3002 <\/p>","protected":false},"excerpt":{"rendered":"

    ResponsiveVoice\u662f\u4e00\u4e2a\u8457\u540d\u800c\u4e14\u514d\u8d39\u7684\u6587\u672c\u53d1\u97f3API\u5de5\u5177\uff0c\u5141\u8bb8\u7528\u6237<\/p>","protected":false},"author":1,"featured_media":3832,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"jetpack_sharing_enabled":true,"jetpack_featured_media_url":"https:\/\/kevinbk.com\/wp-content\/uploads\/2022\/11\/javascript.jpg","_links":{"self":[{"href":"https:\/\/kevinbk.com\/zh\/wp-json\/wp\/v2\/posts\/3951"}],"collection":[{"href":"https:\/\/kevinbk.com\/zh\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/kevinbk.com\/zh\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/kevinbk.com\/zh\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/kevinbk.com\/zh\/wp-json\/wp\/v2\/comments?post=3951"}],"version-history":[{"count":4,"href":"https:\/\/kevinbk.com\/zh\/wp-json\/wp\/v2\/posts\/3951\/revisions"}],"predecessor-version":[{"id":3956,"href":"https:\/\/kevinbk.com\/zh\/wp-json\/wp\/v2\/posts\/3951\/revisions\/3956"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/kevinbk.com\/zh\/wp-json\/wp\/v2\/media\/3832"}],"wp:attachment":[{"href":"https:\/\/kevinbk.com\/zh\/wp-json\/wp\/v2\/media?parent=3951"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/kevinbk.com\/zh\/wp-json\/wp\/v2\/categories?post=3951"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}