當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript jsdom.env函數代碼示例

本文整理匯總了TypeScript中jsdom.env函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript env函數的具體用法?TypeScript env怎麽用?TypeScript env使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了env函數的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: function

        }, function(error: any, response: any, body: any) {

            var licenseInfo: TLicenseInfo = {
                name: '',
                abbreviation: '',
                homepage: '',
                licenseText: ''
            };

            jsdom.env({
                html: body,
                scripts: [jqueryPath],
//                scripts: ['http://code.jquery.com/jquery-1.6.min.js'],
                done: function(err, window){
                    //Use jQuery just as in a regular HTML page
                    var $ = window.jQuery;
                    var title = $('#license').find('h1 a[title]').attr('title');
                    var match = /(.*)\((.+)\)/.exec(title);
                    if (match) {
                        licenseInfo.name = trim(match[1]);
                        licenseInfo.abbreviation = trim(match[2]);
                    } else {
                        licenseInfo.name = trim(title);
                    }
                    var $licenseUrlLabel = $('p:contains("Read more about this license")');
                    licenseInfo.homepage = $licenseUrlLabel.children('a').attr('href');
                    var licenseText = $licenseUrlLabel.prev().text();
                    licenseInfo.licenseText = licenseText.indexOf('Provide') == 0 ? '' : licenseText;
                    cb(err, licenseInfo);
                }
            });
        });
開發者ID:swcho,項目名稱:ossdb,代碼行數:32,代碼來源:OpenHubService.ts

示例2: beforeEach

 beforeEach((done) => {
   const camera = new THREE.PerspectiveCamera(50, 2, 1, 1000);
   const document = jsdom.env('<html><body><div id="container"></div></body></html>', (err, _window_) => {
     if (err) return done(err);
     window = _window_;
     container = window.document.getElementById( 'container' );
     controls = new OrbitControls(camera, container, window);
     done();
   });
 });
開發者ID:jannhendrik,項目名稱:three-orbitcontrols-ts,代碼行數:10,代碼來源:index.spec.ts

示例3: reject

 return new Promise<Window>((resolve, reject) => {
     jsdom.env(html, (error, window) => {
         if (error) {
             reject(error);
         }
         else {
             resolve(window);
         }
     });
 });
開發者ID:SaschaNaz,項目名稱:webxml,代碼行數:10,代碼來源:webxml.ts

示例4:

		fs.readFile(this.scriptPath, { encoding: 'utf-8' }, (err, lib) => {
			if (err) {
				throw err;
			}
			jsdom.env({
				html: source || '<html><body></body></html>',
				src: [lib],
				features: {
					FetchExternalResources: false,
					ProcessExternalResources: false
				},
				done: (errors, window) => {
					willLoadWindow.resolve(window);
				}
			});
		});
開發者ID:jedmao,項目名稱:bindr,代碼行數:16,代碼來源:Engine.ts

示例5: beforeEach

beforeEach(done => {
  jsdom.env({
    html: '<!doctype html><html><body></body></html>',
    scripts: [],
    done(err, createdWindow) {
      if (err) {
        return done(err);
      }

      global['window'] = createdWindow;
      global['document'] = createdWindow.document;
      global['navigator'] = createdWindow.navigator;

      done();
    }
  });
});
開發者ID:ompanda,項目名稱:gulp-typescript-webpack-react-hotreload,代碼行數:17,代碼來源:jsdom-helper.ts

示例6: reject

 return clientPromise = new Promise<Window>((resolve, reject) => {
   jsdom.env({
     file: htmlPath,
     scripts: [ jQueryPath, bootstrapPath ],
     done: (error, window) => {
       if (error) {
         reject(error);
       } else {
         const w = window as any;
         // Can we use jQuery?
         if (w.$) {
           w.$(window.document).ready(() => {
             resolve(window);
           });
         } else {
           reject(new Error('Window does not have global jQuery ($)'));
         }
       }
     }
   });
 });
開發者ID:zthomae,項目名稱:xanadu,代碼行數:21,代碼來源:debugSpec.ts

示例7: Error

 clientPromise = new Promise<WindowAndJQuery>((resolve) => {
   // XXX: should virtualConsole be set?
   jsdom.env({
     file: htmlPath,
     scripts: [jqueryPath, bootstrapPath],
     done: (error, window) => {
       if (error) {
         throw error;
       } else {
         if ((window as any).$) {
           (window as any).$(window.document).ready(function () {
             resolve({
               window,
               $: (window as any).$
             });
           });
         } else {
           throw new Error('jQuery not attached to window!');
         }
       }
     }
   });
 });
開發者ID:zthomae,項目名稱:xanadu,代碼行數:23,代碼來源:clientSpec.ts

示例8: beforeEach

beforeEach(function(done) {
    if ($) {
        done();
        return;
    }

    var fs = require('fs')
    var jsdom = require('jsdom');

    jsdom.env({

        html: '<html><body></body></html>',
        src: [
            fs.readFileSync('install/lib/jquery/jquery.js', 'utf-8'),
            fs.readFileSync('install/js/listcontrol.js', 'utf-8')
        ],
        done: function (err, window) {
            $ = window.jQuery;
            MSOC = window.Microsoft.Office.Controls;
            done();
        }
    });
});
開發者ID:Microsoft,項目名稱:kGrid,代碼行數:23,代碼來源:unittest.jasmine.spec.ts

示例9: mockDom

function mockDom( aScriptFiles, aDoneCallback ) {

    let scripts = loadScripts( aScriptFiles );

    jsdom.env({
        html: `<html><body><div id="${ VIEW_ELEMENT_ID }" style="width:500px; height:400px;"></div></body></html>`,
        src:  scripts,
        done: onDomLoaded
    });

    function loadScripts( aScriptFiles ) {
        var iScripts = [];
        aScriptFiles.forEach( function( aScriptFile ){
            var iScript = fs.readFileSync( aScriptFile, 'utf-8' );
            iScripts.push( iScript );
        });
        return iScripts;
    }

    function onDomLoaded( aError, aWindow ) {
        if ( aError ) {
            throw new Error( aError )
        } else {
            mockContext( aWindow.document );
            overrideOffsetGetters( aWindow );
            setGlobals( aWindow );
        }
        aDoneCallback();
    }

    function mockContext( aDocument ) {
        var originalCreateElement = aDocument.createElement;
        aDocument.createElement = function( tagName ) {
            var element = originalCreateElement.call( aDocument, tagName );
            if ( tagName.toLowerCase() === 'canvas' ) {
                element.getContext = function() {
                    return new Context2DMock();
                }
            }
            return element;
        };
    }

    function overrideOffsetGetters( aWindow ) {

        Object.defineProperties( aWindow.HTMLElement.prototype, {
            offsetLeft: {
                get: function() { return parseFloat( aWindow.getComputedStyle(this).left) || 0; }
            },
            offsetTop: {
                get: function() { return parseFloat( aWindow.getComputedStyle(this).top) || 0; }
            },
            offsetHeight: {
                get: function() { return parseFloat( aWindow.getComputedStyle(this).height) || 0; }
            },
            offsetWidth: {
                get: function() { return parseFloat( aWindow.getComputedStyle(this).width) || 0; }
            }
        });
    }

    function setGlobals( aWindow ) {
        global.window   = aWindow;
        global.document = aWindow.document;
        global.gefri    = aWindow.gefri;
    }

}
開發者ID:Izhaki,項目名稱:gefri,代碼行數:68,代碼來源:mockDom.ts


注:本文中的jsdom.env函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。