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


TypeScript UrlResolver.resolve方法代碼示例

本文整理匯總了TypeScript中angular2/src/services/url_resolver.UrlResolver.resolve方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript UrlResolver.resolve方法的具體用法?TypeScript UrlResolver.resolve怎麽用?TypeScript UrlResolver.resolve使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在angular2/src/services/url_resolver.UrlResolver的用法示例。


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

示例1: it

 it('should support absolute urls', () => {
   expect(resolver.resolve('http://www.foo.com', '/bar')).toEqual('http://www.foo.com/bar');
   expect(resolver.resolve('http://www.foo.com/', '/bar')).toEqual('http://www.foo.com/bar');
   expect(resolver.resolve('http://www.foo.com/baz', '/bar'))
       .toEqual('http://www.foo.com/bar');
   expect(resolver.resolve('http://www.foo.com/baz/', '/bar'))
       .toEqual('http://www.foo.com/bar');
 });
開發者ID:goderbauer,項目名稱:angular,代碼行數:8,代碼來源:url_resolver_spec.ts

示例2: it

 it('should support ".." in the path', () => {
   expect(resolver.resolve('http://www.foo.com/baz/', '../bar'))
       .toEqual('http://www.foo.com/bar');
   expect(resolver.resolve('http://www.foo.com/1/2/3/', '../../bar'))
       .toEqual('http://www.foo.com/1/bar');
   expect(resolver.resolve('http://www.foo.com/1/2/3/', '../biz/bar'))
       .toEqual('http://www.foo.com/1/2/biz/bar');
   expect(resolver.resolve('http://www.foo.com/1/2/baz', '../../bar'))
       .toEqual('http://www.foo.com/bar');
 });
開發者ID:AsherBarak,項目名稱:angular,代碼行數:10,代碼來源:url_resolver_spec.ts

示例3: _inlineImports

  _inlineImports(cssText: string, baseUrl: string,
                 inlinedUrls: List<string>): SyncAsyncResult<string> {
    var partIndex = 0;
    var parts = StringWrapper.split(cssText, _importRe);

    if (parts.length === 1) {
      // no @import rule found, return the original css
      return new SyncAsyncResult(cssText, null);
    }

    var promises = [];

    while (partIndex < parts.length - 1) {
      // prefix is the content before the @import rule
      var prefix = parts[partIndex];
      // rule is the parameter of the @import rule
      var rule = parts[partIndex + 1];
      var url = _extractUrl(rule);
      if (isPresent(url)) {
        url = this._urlResolver.resolve(baseUrl, url);
      }
      var mediaQuery = _extractMediaQuery(rule);
      var promise;

      if (isBlank(url)) {
        promise = PromiseWrapper.resolve(`/* Invalid import rule: "@import ${rule};" */`);
      } else if (ListWrapper.contains(inlinedUrls, url)) {
        // The current import rule has already been inlined, return the prefix only
        // Importing again might cause a circular dependency
        promise = PromiseWrapper.resolve(prefix);
      } else {
        ListWrapper.push(inlinedUrls, url);
        promise = PromiseWrapper.then(this._xhr.get(url), (rawCss) => {
          // resolve nested @import rules
          var inlinedCss = this._inlineImports(rawCss, url, inlinedUrls);
          if (isPresent(inlinedCss.asyncResult)) {
            // wait until nested @import are inlined
            return inlinedCss.asyncResult.then(
                (css) => {return prefix + this._transformImportedCss(css, mediaQuery, url) + '\n'});
          } else {
            // there are no nested @import, return the css
            return prefix + this._transformImportedCss(inlinedCss.syncResult, mediaQuery, url) +
                   '\n';
          }
        }, (error) => `/* failed to import ${url} */\n`);
      }
      ListWrapper.push(promises, promise);
      partIndex += 2;
    }

    return new SyncAsyncResult(null, PromiseWrapper.all(promises).then(function(cssParts) {
      var cssText = cssParts.join('');
      if (partIndex < parts.length) {
        // append then content located after the last @import rule
        cssText += parts[partIndex];
      }
      return cssText;
    }));
  }
開發者ID:baraksu,項目名稱:angular,代碼行數:59,代碼來源:style_inliner.ts

示例4:

    return StringWrapper.replaceAllMapped(cssText, re, (m) => {
      var pre = m[1];
      var url = StringWrapper.replaceAll(m[2], _quoteRe, '');
      var post = m[3];

      var resolvedUrl = this._resolver.resolve(baseUrl, url);

      return pre + "'" + resolvedUrl + "'" + post;
    });
開發者ID:AsherBarak,項目名稱:angular,代碼行數:9,代碼來源:style_url_resolver.ts

示例5:

    return StringWrapper.replaceAllMapped(cssText, re, (m) => {
      var pre = m[1];
      var originalUrl = m[2];
      if (RegExpWrapper.test(_dataUrlRe, originalUrl)) {
        // Do not attempt to resolve data: URLs
        return m[0];
      }
      var url = StringWrapper.replaceAll(originalUrl, _quoteRe, '');
      var post = m[3];

      var resolvedUrl = this._resolver.resolve(baseUrl, url);

      return pre + "'" + resolvedUrl + "'" + post;
    });
開發者ID:KenWilliamson,項目名稱:Angular2HostedMobileApp,代碼行數:14,代碼來源:style_url_resolver.ts

示例6: expect

 expect(() => { resolver.resolve('http://www.foo.com/1/2', '/test'); }).toThrowError();
開發者ID:AsherBarak,項目名稱:angular,代碼行數:1,代碼來源:url_resolver_spec.ts


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