Reputation: 56912
In Java, I might have an interface IsSilly
and one or more concrete types that implement it:
public interface IsSilly {
public void makePeopleLaugh();
}
public class Clown implements IsSilly {
@Override
public void makePeopleLaugh() {
// Here is where the magic happens
}
}
public class Comedian implements IsSilly {
@Override
public void makePeopleLaugh() {
// Here is where the magic happens
}
}
What's the equivalent to this code in Dart?
After perusing the official docs on classes, it doesn't seem that Dart has a native interface
type. So, how does the average Dartisan accomplish the interface segregation principle?
Upvotes: 129
Views: 111612
Reputation: 10707
The other answers do a good job at informing about interfaces with methods.
If you're looking for an interface with properties, you can use getters:
abstract class AppColors {
Color get primary;
Color get secondary;
}
class AppColorsImpl implements AppColors {
@override
Color get primary => Colors.red;
@override
Color get primary => Colors.blue;
}
And yes, you can combine an interface to have both properties and methods too.
--- Updated --- With version 3.0 Dart added support for Class modifiers:
https://dart.dev/language/class-modifiers
Upvotes: 6
Reputation: 76253
In Dart there is a concept of implicit interfaces.
Every class implicitly defines an interface containing all the instance members of the class and of any interfaces it implements. If you want to create a class A that supports class B’s API without inheriting B’s implementation, class A should implement the B interface.
A class implements one or more interfaces by declaring them in an
implements
clause and then providing the APIs required by the interfaces.
So your example can be translate in Dart like this :
abstract class IsSilly {
void makePeopleLaugh();
}
class Clown implements IsSilly {
void makePeopleLaugh() {
// Here is where the magic happens
}
}
class Comedian implements IsSilly {
void makePeopleLaugh() {
// Here is where the magic happens
}
}
Upvotes: 194
Reputation: 1615
This is a class or an interface depending on the situation.
abstract class A {
void sayHello() {
print("Hello");
}
void sayBye();
}
B class implements A interface, so it has to implements all methods of A.
class B implements A {
void sayHello() {
print("B say Hello");
}
void sayBye() {
print("B say Bye");
}
}
C class extends A class, so it has to implement all abstract methods of A. (Not all). C is inherited the sayHello() methods from A class.
class C extends A {
void sayBye() {
print("C say Bye");
}
}
Upvotes: 3
Reputation: 1312
abstract class ORMInterface {
void fromJson(Map<String, dynamic> _map);
}
abstract class ORM implements ORMInterface {
String collection = 'default';
first(Map<String, dynamic> _map2) {
print("Col $collection");
}
}
class Person extends ORM {
String collection = 'persons';
fromJson(Map<String, dynamic> _map) {
print("Here is mandatory");
}
}
Upvotes: 4
Reputation: 5600
The confusion usually is because doesn't exist the word "interface" like java and another languages. Class declarations are themselves interfaces in Dart.
In Dart every class defines an implicit interface like others says.So then... the key is: Classes should use the implements keyword to be able to use an interface.
abstract class IsSilly {
void makePeopleLaugh();
}
//Abstract class
class Clown extends IsSilly {
void makePeopleLaugh() {
// Here is where the magic happens
}
}
//Interface
class Comedian implements IsSilly {
void makePeopleLaugh() {
// Here is where the magic happens
}
}
Upvotes: 21
Reputation: 21383
In Dart, every class defines an implicit interface. You can use an abstract class to define an interface that cannot be instantiated:
abstract class IsSilly {
void makePeopleLaugh();
}
class Clown implements IsSilly {
void makePeopleLaugh() {
// Here is where the magic happens
}
}
class Comedian implements IsSilly {
void makePeopleLaugh() {
// Here is where the magic happens
}
}
Upvotes: 18