• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            雖不能至,心向往之

            —— 巴人也,操C++口音,混跡于京師,勉強度日……《史記·corelito列傳》
            posts - 8, comments - 15, trackbacks - 0, articles - 0

            使用V8——Google Chrome 的 JavaScript 引擎(3)

            Posted on 2008-10-19 23:35 sufan 閱讀(2993) 評論(1)  編輯 收藏 引用 所屬分類: 翻譯
            訪問器——訪問腳本中的變量
            我們已經能夠在腳本中使用函數了。但如果我們能夠使用在腳本中定義的變量什么的豈不是更好?說做就做!V8有一個叫做訪問器的東西,有了它,我們就能通過名字來使用變量以及與它相關的兩個Set/Get函數,在運行腳本程序的時候,V8就是通過這兩個函數來實現對變量的訪問。

            global->SetAccessor(v8::String::New("x"), XGetter, XSetter);

            這行代碼就將“x”與“XGetter”和“XSetter”函數聯系在一起了。當V8需要得到“x”變量的值的時候,它就會去調用“XGetter”函數,相類似的,如果V8要更新“x”變量的值的時候,它調用的是“XSetter”函數。現在,我們的代碼成了:

            //the x variable!
            int x;

            //
            get the value of x variable inside javascript
            static v8::Handle<v8::Value> XGetter( v8::Local<v8::String> name, 
                              
            const v8::AccessorInfo& info) {
              
            return  v8::Number::New(x);
            }

            //
            set the value of x variable inside javascript
            static void XSetter( v8::Local<v8::String> name, 
                   v8::Local
            <v8::Value> value, const v8::AccessorInfo& info) {
              x 
            = value->Int32Value();
            }

            在 XGetter 函數中,我們所要做的只是將“x”轉換成V8所能管理的 Number 類型的值。而在 XSetter 函數中,我們需要將這個作為參數傳過來的值轉換成一個整數。就像對應其基類型的函數,例如 NumberValue 之于 double,BooleanValue 之于 bool,等等。

            對于 char * 類型的字符串,我們同樣有:

            //the username accessible on c++ and inside the script
            char username[1024];

            //
            get the value of username variable inside javascript
            v8::Handle<v8::Value> userGetter(v8::Local<v8::String> name, 
                       
            const v8::AccessorInfo& info) {
                
            return v8::String::New((char*)&username,strlen((char*)&username));
            }

            //
            set the value of username variable inside javascript
            void userSetter(v8::Local<v8::String> name, v8::Local<v8::Value> value,
                
            const v8::AccessorInfo& info) {
                v8::Local
            <v8::String> s = value->ToString();
                s
            ->WriteAscii((char*)&username);
            }

             

            對于字符串,情況就有一點小小的變化了。userGetter 以 XGetter 相類似的方式創建了一個新字符串,但是 userSetter 首先需要使用 ToString 函數來訪問內部字符串緩沖區。然后,我們通過得到的指向內部字符串對象的指針,使用 WriteAscii 函數將字符串的內容寫到我們的緩沖區。最后添加相對應的訪問器,一切搞定!

            //create accessor for string username
            global->SetAccessor(v8::String::New("user"),userGetter,userSetter);

            Feedback

            # re: 使用V8——Google Chrome 的 JavaScript 引擎(3)  回復  更多評論   

            2011-07-07 13:19 by 有趣之極
            很好,學習
            91久久精品视频| 中文字幕乱码久久午夜| 国产成人无码精品久久久久免费| 精品一区二区久久久久久久网站| 99久久精品费精品国产| 亚洲v国产v天堂a无码久久| 日韩精品久久久肉伦网站| 国产精品免费看久久久香蕉| 久久精品一区二区三区AV| 大蕉久久伊人中文字幕| 性欧美丰满熟妇XXXX性久久久 | 看全色黄大色大片免费久久久| 久久久久亚洲AV无码观看| 国产精品va久久久久久久| 久久九九精品99国产精品| 伊人久久大香线蕉综合5g| 狠色狠色狠狠色综合久久| 蜜臀久久99精品久久久久久小说| 国产激情久久久久影院小草| 东京热TOKYO综合久久精品| 久久国产成人午夜aⅴ影院 | 久久水蜜桃亚洲av无码精品麻豆| 亚洲综合婷婷久久| 久久99热国产这有精品| 青草国产精品久久久久久| 亚洲欧美久久久久9999| 久久se这里只有精品| 99久久精品国产一区二区| 99re久久精品国产首页2020| 伊人久久大香线蕉综合影院首页| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区| 狠狠色丁香婷婷久久综合不卡| 久久精品亚洲精品国产色婷| 久久国产高潮流白浆免费观看| 伊人久久综合成人网| 亚洲国产欧美国产综合久久| 成人午夜精品无码区久久| 狠狠精品久久久无码中文字幕| 久久久久久曰本AV免费免费| 国产成人精品久久| 精品久久久无码人妻中文字幕豆芽|