成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

React框架實現(xiàn)移動頁面翻譯是一種什么體驗?

馬永翠 / 1795人閱讀

摘要:但是可以做到將內(nèi)容中的英文單詞翻譯出來,是怎么實現(xiàn)的呢一起來看一下吧。處理中的單詞由于傳給我的是一大段內(nèi)容,里面的元素的類型不只一種類名也不止一種,有等等,但是我只處理面積最大的一塊英文,也就是只處理中的英文單詞這就好辦了。

單詞翻譯常見于APP中,那么在網(wǎng)頁中對于一段中英混雜的內(nèi)容怎么準確的做到單詞的翻譯呢?

我要渲染的內(nèi)容是一段段的html,用react渲染一段html內(nèi)容是沒有什么難度,使用dangerouslySetInnerHTML 即可。但是可以做到將內(nèi)容中的英文單詞翻譯出來,是怎么實現(xiàn)的呢?一起來看一下吧。

效果

事情是這樣的...

我前端是做內(nèi)容展示,后臺將Html格式的內(nèi)容傳遞到前端,前端原生元素的dangerouslySetInnerHTML 屬性去解析html內(nèi)容,就可以使用react框架渲染html了

仔細看,這個屬性用的是{{ }}2個括號而不是1個括號。原因是:第一{}代表jsx語法開始,第二個是代表dangerouslySetInnerHTML接收的是一個對象鍵值對。它接收的內(nèi)容是html的,很容易收到XSS攻擊,所以這個屬性有了dangerous這個單詞...

過程

重組英文單詞

后臺傳給我的一段一段的內(nèi)容是這樣的:

既然要提取出來做單詞翻譯,就得有能力去獲取每一個單詞,所以我的打算是,把內(nèi)容提取出來,是一個英文單詞就放進一個span標簽中。但是這一步在哪里處理比較好呢,我想了想,在頁面渲染之前處理吧, 這樣頁面渲染的壓力要減小,提高渲染速度。所以我在前端接收到后端發(fā)送的數(shù)據(jù)之后,在存入store之前就先處理好。

        case "OBT_BOOK_CONTENT_SUCCESS":
            var newContents = action.meta.bookcontent.map((item, index) => {
                item.paragraphContent = item.paragraphContent.replace(/src="/g, `src="${url}`);
                //處理caseContent中的單詞
                var div = document.createElement("div");
                div.innerHTML = item.paragraphContent;
                var caseContent = div.querySelector(".caseContent");

                if (caseContent) {
                    var arr = caseContent.innerText.split(" ");
                    for (var i = 0; i < arr.length; i++) {
                        arr[i] = "" + arr[i] + ""
                    }
                    caseContent.innerHTML = arr.join("");
                    item.paragraphContent = div.innerHTML;
                }
                return item;
            })
            return Object.assign({}, state, {
                bookcontent: newContents
            })

由于傳給我的是一大段內(nèi)容,里面的元素的類型不只一種、類名也不止一種,有div .caseTitle .caseContent strong等等,但是我只處理面積最大的一塊英文,也就是只處理caseContent中的英文單詞這就好辦了。我沒有用string的方法,去查找這個串在什么位置,怎么截取怎么拼接。沒有。我利用了DOM的原理,借助DOM原生的api幫助我得到我要的英文單詞。我創(chuàng)建了一個div(沒有DOM我就自己創(chuàng)建DOM咯),然后DOM查找.caseContent ,用空格把其中的所有單詞提取出來,再給每一個單詞用span包起來,然后把.caseContent中的內(nèi)容替換掉,同時div的innerHTML也就變了,最后改變paragraphContent。就這樣把后端傳過來的東西做了修改,再使用。

提取單詞
由于我想要翻譯的單詞是用span包裹的,所以我需要檢查用戶點擊屏幕所在的節(jié)點是不是span

if(e.target.nodeName === "SPAN"){
        var s = "";
       if(e.target.innerText) {
            var len = e.target.innerText.length;
            if( !/^[u4e00-u9fa5]{0,}$/.test(e.target.innerText) ){
                if(e.target.innerText[len -1 ] === "," || e.target.innerText[len -1 ] === "." ){
                    s = e.target.innerText.substring(0, len -1 )
                }else {
                    s = e.target.innerText;
                }
                var chooseSpan =   e.target;
               
                this.props.checkWords(s, chooseSpan);
            }
       }
       console.log( s);
    }

利用正則!/^[u4e00-u9fa5]{0,}$/提取出來英文單詞,但是有些單詞末尾會帶著英文狀態(tài)下的逗號,句號.,所以還需要用substring剪切一下單詞,再調(diào)用方法。

這里,提取頁面中點擊的內(nèi)容,需要CSS的配合。

user-select: text;

user-selct: text;可以讓頁面中的內(nèi)容被選中。而 user-select: none是讓頁面中的內(nèi)容不被選中。

  -ms-user-select: none;
  -webkit-user-select: none;
  user-select: none;

獲取了單詞s之后,還需要做一點交互,就是被選中的單詞高亮起來,所有,span元素也需要被處理,為了嚴謹,所以需要再判斷是不是單詞,是的話,再對span 做處理。

 checkWords(txt, selectedSpan) {
    // 查單詞
   
    this.selectedSpan = selectedSpan;
    if (txt.toString().length > 1) {
      if (/^w+$/.test(txt)) {
        this.props.getWord(txt);
        this.setState({
          showWord: true
        })
        selectedSpan.style.color="#fff";
        selectedSpan.style.backgroundColor="rgb(0,153,223)";
      }
    }
  }

請求翻譯接口

getWord方法中調(diào)用了查單詞的api,我用的是有道智云的api,需要自己注冊一個賬號,然后申請一個應(yīng)用。獲取appKey和appSecret,設(shè)置好from 和 to 的值,也就是你要從什么語言轉(zhuǎn)什么語言,準備一個隨機數(shù)sale, 然后各種生成簽名。。

var appSecret = "GOPjZoiSnH592P31Qn6xoallHn3zUnSh";
  var appKey = "06fc15a9c06cb290";
  var salt = "" + (new Date).getTime();
  // 多個query可以用
連接  如 query="apple
orange
banana
pear"
  var from = "en";
  var to = "zh-CHS";
  var str1 = appKey + q + salt + appSecret;
  var data = null;
  var sign = md5(str1);
  var sendRes = res;
  sign = sign.toUpperCase();
  q = encodeURI(q);
  var url = `http://openapi.youdao.com/api?q=${q}&from=${from}&to=${to}&appKey=${appKey}&salt=${salt}&sign=${sign}`

有了這個url之后,就可以請求了。返回的東西是:

播放單詞的地方就是用 H5的audio 元素,src是
http://dict.youdao.com/dictvoice?audio=${this.props.word.query}

后來發(fā)現(xiàn)扇貝的單詞api做的也不錯,沒有有道用的這么麻煩,有道還需要簽名,用戶量大的時候也會有限制,準備以后換扇貝的。

至此,使用react框架完成移動頁面的定向單詞翻譯已完成。其中配合了CSS,DOM,正則,使用別家api等知識,算是一次小小的綜合考核吧,不知道有沒有其他同學也做過這樣的事情,如果有的話,可以交流一下啊。

完畢。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/115793.html

相關(guān)文章

  • React框架實現(xiàn)移動頁面翻譯一種什么體驗?

    摘要:但是可以做到將內(nèi)容中的英文單詞翻譯出來,是怎么實現(xiàn)的呢一起來看一下吧。處理中的單詞由于傳給我的是一大段內(nèi)容,里面的元素的類型不只一種類名也不止一種,有等等,但是我只處理面積最大的一塊英文,也就是只處理中的英文單詞這就好辦了。 單詞翻譯常見于APP中,那么在網(wǎng)頁中對于一段中英混雜的內(nèi)容怎么準確的做到單詞的翻譯呢? 我要渲染的內(nèi)容是一段段的html,用react渲染一段html內(nèi)容是沒有什...

    bingo 評論0 收藏0
  • Angular2, NativeScript 和 React Native比較[翻譯]

    摘要:當開始使用來提供真正的跨平臺應(yīng)用時,他發(fā)現(xiàn)對的緊耦合的依賴性在用開發(fā)應(yīng)用創(chuàng)建映射時呈現(xiàn)的問題。的重點放在高性能的渲染和執(zhí)行上,你可以很輕松的創(chuàng)建高性能的跨平臺應(yīng)用,這些應(yīng)用可以在相同的代碼庫上運行并且隨意使用特點平臺的組件。 showImg(https://segmentfault.com/img/bVJi8d?w=980&h=400); 在開發(fā)階段,跨平臺開發(fā)App面臨一個很重要的決...

    cooxer 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<