WORD多合1显示;同时显示多行,一行变多行;

先上效果图,实现思路写在前面文章

WPS拼音指南乱用;切换域代码乱用_countsun的博客-CSDN博客

功能在微信小程序-复制就好

进去后 选WORD多合一显示;

点进去有操作说明:

1、复制需要的文本
2、设置一下每行的格式(可以用默认的)
4、点运行
5、粘贴到一个txt文件,然后重名为abc.xml
6、用word打开这个abc.xml 就可以看到内容

默认例子写了5行,可以改成6行,7行,看自己的需要

改6行就是 ws6加上,改wshow,jsf6 加上,改jshow;应该就行了,自己测试几次应该就每问题;

另外格式可以修改 字体,字体大小和字体颜色;其他没研究,应该也能改。

比如适用于4行

第一行英文,

第二行英文音标,

第三行英文音标汉字读法,

第四行,中文意思,

比如good,/ɡʊd/,古德,好的; 这4个显示。

  var result ='ok'
  //显示的内容,可以用参数凭接 ws1 最底下,以此网上
  var ws1=['a1b','中1国1','a3','9m4','1d5']
  var ws2=['a2b','中2国1','a3','8m4','2d5']
  var ws3=['a3b','中3国1','a3','7m4','3d5']
  var ws4=['a4b','中4国1','a3','6m4','4d5']
  var ws5=['a5b','中5国1','a3','5m4','4d5']
  ws1=[]; ws2=[]; ws3=[]; ws4=[];ws5=[];
  let str=app.data.copyStr
for(let i=0;i<str.length;i++)
{
  console.log(i,str.length)
  ws1.push(str.slice(i,i+1))
  ws2.push(str.slice(i,i+1))
  ws3.push(str.slice(i,i+1))
  ws4.push(str.slice(i,i+1))
  ws5.push(str.slice(i,i+1))
if(i>300){break}
}
  var wshow=[ws1,ws2,ws3,ws4,ws5]

  var jsf1={dfont:'"Arial"',//正文字体,有引号注意,其实就是a1d的字体,只有第一个有用
  color:'"FF0033"',//正文颜色,有引号注意,默认黑色,颜色只有一个地方设置
  dsize:'"120"',//24等于12磅字,除以2,有引号 其实就是a1d的字体大小,只有第一个有用
}
var jsf2={
color:'"FF6600"',//颜色,有引号注意
ufont:'宋体',//音标字体,没引号
usize:'hps100',//20磅
uhigh:'up 59',//11表示24/2-1,距离是0,这个24是downword的尺寸,如果是40,那么要填写19,这里24就是jsf1里的24
//59表示120/2-1,距离是0,这个120是downword的尺寸,如果是40,那么要填写19,这里120就是jsf1里的120
}
var jsf3={
color:'"FFFF00"',//颜色,有引号注意
ufont:'华文行楷',//音标字体,没引号
usize:'hps100',//12磅
uhigh:'up 49',//11表示24/2-1,距离是0,这个24是downword的尺寸,如果是40,那么要填写19
}
var jsf4={
color:'"00FF00"',//颜色,有引号注意
ufont:'华文彩云',//音标字体,没引号
usize:'hps100',//12磅
uhigh:'up 49',//11表示24/2-1,距离是0,这个24是downword的尺寸,如果是40,那么要填写19
}
var jsf5={
color:'"33FFFF"',//颜色,有引号注意
ufont:'Arial Unicode MS',//音标字体,没引号
usize:'hps100',//12磅
uhigh:'up 49',//11表示24/2-1,距离是0,这个24是downword的尺寸,如果是40,那么要填写19
}
var jshow=[jsf1,jsf2,jsf3,jsf4,jsf5]
//console.log(jshow,jshow[1].dfont)
  let bk4='    '
      //wordtemplatee=<?xml 有空格是不行的
      let wordtemplate='<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <?mso-application progid="Word.Document"?> <w:wordDocument xmlns:w="http://schemas.microsoft.com/office/word/2003/wordml"> <w:docPr>  <w:view w:val="print"/> <w:zoom w:percent="120"/>     </w:docPr> <w:body> <w:p> <w:r>  </w:r> </w:p>   </w:body>    <w:sectPr>    </w:sectPr>    </w:wordDocument>'
      let wpbegin='<w:p>'
      let wpend='</w:p>'
      let bodyend='</w:body>'
      let outstr=''
      // easyword 表示普通的文字,不用多合一
      let easyword='<w:r><w:rPr><w:rFonts w:ascii="Arial" w:h-ansi="Arial" w:cs="Arial" w:hint="fareast"/><w:color w:val="FF0000"/><w:sz w:val="24"/><w:sz-cs w:val="24"/><w:lang w:val="EN-US" w:fareast="ZH-CN"/></w:rPr><w:t>easyword</w:t></w:r>'
      let copyword=wordtemplate
      let bl=copyword.indexOf(wpbegin)
     let bodybegin=copyword.slice(0,bl)
     let el=copyword.indexOf(bodyend)
     bodyend=copyword.slice(el)
// c1str 把upword 替换成c1str就是递归,把\ 改成\\  原字符串 <w:r><w:rPr></w:rPr><w:fldChar w:fldCharType="begin"/></w:r><w:r><w:rPr></w:rPr><w:instrText> EQ \* jc0 \* &quot;Font:Arial Unicode MS&quot; \* hps40 \o \ad(\s \up 11(</w:instrText></w:r><w:r><w:rPr><w:color w:val="FF0000"/></w:rPr><w:instrText>upword)</w:instrText></w:r><w:r><w:rPr><w:rFonts w:ascii="Arial" w:h-ansi="Arial" w:cs="Arial" w:hint="default"/><w:sz w:val="24"/><w:sz-cs w:val="24"/><w:color w:val="000000"/></w:rPr><w:instrText>,downword)</w:instrText></w:r><w:r><w:rPr></w:rPr><w:fldChar w:fldCharType="end"/></w:r>
 let c1str='<w:r><w:rPr></w:rPr><w:fldChar w:fldCharType="begin"/></w:r><w:r><w:rPr></w:rPr><w:instrText> EQ \\* jc0 \\* &quot;Font:Arial Unicode MSx&quot; \\* hps40x \\o \\ad(\\s \\up 11x(</w:instrText></w:r><w:r><w:rPr><w:color w:val="FF0000x"/></w:rPr><w:instrText>upword)</w:instrText></w:r><w:r><w:rPr><w:rFonts w:ascii="Arialx" w:h-ansi="Arialx" w:cs="Arialx" w:hint="default"/><w:sz w:val="24x"/><w:sz-cs w:val="24x"/><w:color w:val="000000x"/></w:rPr><w:instrText>,downword)</w:instrText></w:r><w:r><w:rPr></w:rPr><w:fldChar w:fldCharType="end"/></w:r>'
// ccut 只有最下面这个单词的格式才需要再 ccut里边设置,其他都删除;
 let ccut='<w:rFonts w:ascii="Arialx" w:h-ansi="Arialx" w:cs="Arialx" w:hint="default"/><w:sz w:val="24x"/><w:sz-cs w:val="24x"/><w:color w:val="000000x"/>'
 let showall=''
 let l=0
    for(let j=0;j<wshow[0].length;j++)
    {
      outstr=c1str
      for(let i=0;i<wshow.length-2;i++)
      {
       
        if(i==0){
           // 设置a1d的格式
        outstr=replaceall(outstr,'"000000x"',jshow[0].color) 
        outstr=replaceall(outstr,'"Arialx"',jshow[0].dfont) 
        outstr=replaceall(outstr,'"24x"',jshow[0].dsize) 
          // 设置a2d的格式
        outstr=replaceall(outstr,'"FF0000x"',jshow[1].color) 
        outstr=replaceall(outstr,'Arial Unicode MSx',jshow[1].ufont) 
        outstr=replaceall(outstr,'hps40x',jshow[1].usize) 
        outstr=replaceall(outstr,'up 11x',jshow[1].uhigh) 
        }
        else
        {
          // 设置i+2的格式,最后第二个已经设置完格式
          outstr=replaceall(outstr,'"FF0000x"',jshow[i+1].color) 
          outstr=replaceall(outstr,'Arial Unicode MSx',jshow[i+1].ufont) 
          outstr=replaceall(outstr,'hps40x',jshow[i+1].usize) 
          outstr=replaceall(outstr,'up 11x',jshow[i+1].uhigh) 
        }
        outstr=replaceall(outstr,'downword',wshow[i][j])  //a1d 
        outstr=replaceall(outstr,'upword',c1str) 
      }
     
      l=wshow.length   
     // console.log(l0,l0-1,l0-2)
        // 设置最后一个格式
     outstr=replaceall(outstr,'"FF0000x"',jshow[l-1].color) 
     outstr=replaceall(outstr,'Arial Unicode MSx',jshow[l-1].ufont) 
     outstr=replaceall(outstr,'hps40x',jshow[l-1].usize) 
     outstr=replaceall(outstr,'up 11x',jshow[l-1].uhigh) 
       // 最后2个替换
      outstr=replaceall(outstr,'upword',wshow[l-1][j])   //a5d
      outstr=replaceall(outstr,'downword',wshow[l-2][j])     //a4d
      showall=showall+outstr+easyword.replace('easyword',bk4)
   }
   showall=replaceall(showall,ccut,'') 
   outstr=bodybegin+wpbegin+showall+wpend+bodyend
  app.data.outStr=outstr;//把数据传递出去剪贴板数据
//字符替换函数
function replaceall(str, substr, newstr) {
  var p = -1;
  var s = 0; 
    while((p = str.indexOf(substr, s)) > -1) {
    s = p + newstr.length;
    str = str.replace(substr, newstr);
  }
    return str;
};
  app.setData({
    result:'ok' 
     });
  result;//不要修改,这里就是反馈函数的值给外面

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值