When I try to create a Range object in ace.js, an “Illegal Constructor” error is thrown

StackOverflow https://stackoverflow.com/questions/10452869

  •  05-06-2021
  •  | 
  •  

Question

I am trying to create a Range object for the ace.js editor in my code, but it's not working. It is failing in a way I can't figure out. In the Ace documentation, this constructor is:

new Range(Number startRow,
          Number startColumn,
          Number endRow,
          Number endColumn)

But when I try this in my code:

new Range(0, 0, 0, 1)

It raises an Uncaught TypeError: Illegal constructor error. What is causing this behavior, and why doesn't it match the documentation?

Was it helpful?

Solution

Range is a native type is most browsers that you cannot instantiate. I'm not really familiar with Ace, but I'm guessing that they use some sort of namespacing so that you will do something like new Ace.Range().

Edit: It looks like they are using CommonJS, so you can import the method and alias it however you like:

var Range = require('ace/range').Range,
    mine = new Range(0,0,10,0);

OTHER TIPS

Replace require('ace/range').Range with ace.require('ace/range').Range

This worked for me:

import { Range } from "ace-builds"

This solution var Range = ace.acequire('ace/range').Range; works for me!!!

Full code: https://stackoverflow.com/a/53387989/630169

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top