在网页中处理ActiveXObject()的执行结果

简介: 在网页中处理ActiveXObject()的执行结果

如果把《在网页中使用TTS技术的例子 & 备忘录》

 

的演示代码保存为html文件,再在IE中打开,会先出现一个提示框:

 

 

如果用户不小心点击了“否”按钮,后面的代码在执行时就会出错。

 

 

解决方法是用 try{} catch{} 来改写代码:

<SCRIPT LANGUAGE="JavaScript">   
// Create the Sapi SpVoice object
var VoiceObj;

try
{
   VoiceObj = new ActiveXObject("Sapi.SpVoice");
}
catch(e)
{
   //alert(e.message);
   VoiceObj = null;
}

如果用户点击了“否”按钮,我们可以在catch{}中对VoiceObj重新赋值null。

 

后面的代码则根据VoiceObj的值来处理。

 

 

我们需要先把代码:

// Handle EndStream event      
function VoiceObj::EndStream()   
{   
    idbSpeakText.value = "朗读";   
}
  
// Handle StartStream event    
function VoiceObj::StartStream()   
{   
    idbSpeakText.value = "停止";   
}

抽出来,保存到v1.js中,并加以引用。

 

 

完整的代码如下:

<HTML>   
<HEAD>   
<SCRIPT LANGUAGE="JavaScript">   
// Create the Sapi SpVoice object
var VoiceObj;
//alert(typeof(VoiceObj));

try
{
VoiceObj = new ActiveXObject("Sapi.SpVoice");
}
catch(e)
{
   //alert(e.message);
   VoiceObj = null;
}

</SCRIPT>   
  
<SCRIPT LANGUAGE="JavaScript">   
  
// Code in the BODY of the webpage is used to initialize controls and   
// to handle SAPI events   
  
/***** Initializer code *****/  
  
function InitializeControls()   
{   
    // Initialize the Voices and AudioOutput Select boxes   
    var VoicesToken = VoiceObj.GetVoices();   
    var AudioOutputsToken = VoiceObj.GetAudioOutputs();   
}   

if (null != VoiceObj)
{
   InitializeControls();
   document.write(unescape("%3Cscript language=/"javascript/" src=/"v1.js/"%3E%3C//script%3E"));
}
  

  
// SpeakText() function:   
//      This function gets the text from the textbox and sends it to the   
//      Voice object's Speak() function. The value "1" for the second   
//      parameter corresponds to the SVSFlagsAsync value in the SpeechVoiceSpeakFlags   
//      enumerated type.   
function SpeakText()   
{   
//alert(document.body.innerText);   
    if (idbSpeakText.value == "朗读")   
    {   
        // Speak the string in the edit box   
        try  
        {   
            VoiceObj.Speak(document.body.innerText, 1);   
        }   
        catch (exception)   
        {   
            alert("Error");   
        }   
    }   
    else if(idbSpeakText.value == "停止")   
    {   
        // Speak empty string to Stop current speaking. The value "2" for    
        // the second parameter corresponds to the SVSFPurgeBeforeSpeak   
        // value in the SpeechVoiceSpeakFlags enumerated type.   
        VoiceObj.Speak( "", 2);   
    }   
}   
// --></mce:script>   
  
<SCRIPT FOR="window" EVENT="OnQuit()" LANGUAGE="JavaScript">   
    // Clean up voice object   
    delete VoiceObj;   
</SCRIPT>   
</HEAD>   
  
<body>   
<BUTTON id="idbSpeakText" οnclick="SpeakText();">朗读</BUTTON>   
<P>  这场比赛跟我预想的一样,德国队被西班牙玩死了。</P>   
<P>  此前德国队横扫英格兰队和阿根廷队,立即吸引了众多墙头草,被捧为夺冠最大热门。</P>   
<P>  其实熟悉欧洲俱乐部赛事的人都知道,德国俱乐部球队遇上西班牙球队成绩都不太理想。即使在西班牙联赛中水平表现一般的赫塔菲都能给德甲领头羊拜仁慕尼黑制造难堪。作为西甲领头羊的巴萨这几年对德国球队更是捷报频传,对阵不莱梅、斯图加特、沙尔克04、拜仁慕尼黑,不仅比分占优,而且在控球、传球上的技术优势也非常明显。</P>   
<P>  此次西班牙对阵德国,西班牙队内首发的巴萨球员达到7人,除了巴尔德斯外,其他球员全部都上场了,普约尔和皮克坐镇后防线,哈维、布斯克茨、伊涅斯塔打中场,比利亚和佩德罗则打前锋。另外法布雷加斯和雷纳也出自巴萨青训营。而德国队首发阵容中来自拜仁的球员包括克洛泽、施魏因斯泰格和拉姆三人,如果不是托马斯-穆勒累积黄牌停赛,肯定也将是首发中的一员,而波多尔斯基和特罗肖夫斯基也曾在拜仁效力,另外替补席上的巴德施图贝尔、托尼-克罗斯、戈麦斯和布特也都是来自拜仁,也就是说这辆日尔曼战车同样有10名“拜仁帮”的球员。从一定意义上说,这场比赛就是 巴萨 vs 拜仁慕尼黑,西班牙队胜面很大。</P>   
</body>   
</html>
相关文章
|
10天前
|
弹性计算 人工智能 架构师
阿里云携手Altair共拓云上工业仿真新机遇
2024年9月12日,「2024 Altair 技术大会杭州站」成功召开,阿里云弹性计算产品运营与生态负责人何川,与Altair中国技术总监赵阳在会上联合发布了最新的“云上CAE一体机”。
阿里云携手Altair共拓云上工业仿真新机遇
|
6天前
|
机器学习/深度学习 算法 大数据
【BetterBench博士】2024 “华为杯”第二十一届中国研究生数学建模竞赛 选题分析
2024“华为杯”数学建模竞赛,对ABCDEF每个题进行详细的分析,涵盖风电场功率优化、WLAN网络吞吐量、磁性元件损耗建模、地理环境问题、高速公路应急车道启用和X射线脉冲星建模等多领域问题,解析了问题类型、专业和技能的需要。
2506 14
【BetterBench博士】2024 “华为杯”第二十一届中国研究生数学建模竞赛 选题分析
|
6天前
|
机器学习/深度学习 算法 数据可视化
【BetterBench博士】2024年中国研究生数学建模竞赛 C题:数据驱动下磁性元件的磁芯损耗建模 问题分析、数学模型、python 代码
2024年中国研究生数学建模竞赛C题聚焦磁性元件磁芯损耗建模。题目背景介绍了电能变换技术的发展与应用,强调磁性元件在功率变换器中的重要性。磁芯损耗受多种因素影响,现有模型难以精确预测。题目要求通过数据分析建立高精度磁芯损耗模型。具体任务包括励磁波形分类、修正斯坦麦茨方程、分析影响因素、构建预测模型及优化设计条件。涉及数据预处理、特征提取、机器学习及优化算法等技术。适合电气、材料、计算机等多个专业学生参与。
1519 14
【BetterBench博士】2024年中国研究生数学建模竞赛 C题:数据驱动下磁性元件的磁芯损耗建模 问题分析、数学模型、python 代码
|
8天前
|
编解码 JSON 自然语言处理
通义千问重磅开源Qwen2.5,性能超越Llama
击败Meta,阿里Qwen2.5再登全球开源大模型王座
531 13
|
1月前
|
运维 Cloud Native Devops
一线实战:运维人少,我们从 0 到 1 实践 DevOps 和云原生
上海经证科技有限公司为有效推进软件项目管理和开发工作,选择了阿里云云效作为 DevOps 解决方案。通过云效,实现了从 0 开始,到现在近百个微服务、数百条流水线与应用交付的全面覆盖,有效支撑了敏捷开发流程。
19282 30
|
1月前
|
人工智能 自然语言处理 搜索推荐
阿里云Elasticsearch AI搜索实践
本文介绍了阿里云 Elasticsearch 在AI 搜索方面的技术实践与探索。
18836 20
|
1月前
|
Rust Apache 对象存储
Apache Paimon V0.9最新进展
Apache Paimon V0.9 版本即将发布,此版本带来了多项新特性并解决了关键挑战。Paimon自2022年从Flink社区诞生以来迅速成长,已成为Apache顶级项目,并广泛应用于阿里集团内外的多家企业。
17524 13
Apache Paimon V0.9最新进展
|
8天前
|
人工智能 自动驾驶 机器人
吴泳铭:AI最大的想象力不在手机屏幕,而是改变物理世界
过去22个月,AI发展速度超过任何历史时期,但我们依然还处于AGI变革的早期。生成式AI最大的想象力,绝不是在手机屏幕上做一两个新的超级app,而是接管数字世界,改变物理世界。
458 48
吴泳铭:AI最大的想象力不在手机屏幕,而是改变物理世界
|
1天前
|
云安全 存储 运维
叮咚!您有一份六大必做安全操作清单,请查收
云安全态势管理(CSPM)开启免费试用
354 4
叮咚!您有一份六大必做安全操作清单,请查收
|
2天前
|
存储 关系型数据库 分布式数据库
GraphRAG:基于PolarDB+通义千问+LangChain的知识图谱+大模型最佳实践
本文介绍了如何使用PolarDB、通义千问和LangChain搭建GraphRAG系统,结合知识图谱和向量检索提升问答质量。通过实例展示了单独使用向量检索和图检索的局限性,并通过图+向量联合搜索增强了问答准确性。PolarDB支持AGE图引擎和pgvector插件,实现图数据和向量数据的统一存储与检索,提升了RAG系统的性能和效果。